CouchDB - Giriş

Veritabanı yönetim sistemi, verilerin depolanması ve alınması için mekanizma sağlar. RDBMS (İlişkisel Veritabanı yönetim Sistemleri), OLAP (Çevrimiçi Analitik İşleme Sistemleri) ve NoSQL olmak üzere üç ana veritabanı yönetim sistemi türü vardır.

RDBMS

RDBMS, İlişkisel Veritabanı Yönetim Sisteminin kısaltmasıdır. RDBMS, SQL'in ve MS SQL Server, IBM DB2, Oracle, MySQL ve Microsoft Access gibi tüm modern veritabanı sistemlerinin temelidir.

İlişkisel veritabanı yönetim sistemi (RDBMS), EF Codd tarafından sunulan ilişkisel modeli temel alan bir veritabanı yönetim sistemidir (DBMS).

RDBMS'deki veriler, adı verilen veritabanı nesnelerinde saklanır. tables. Tablo, ilgili veri girişlerinin bir koleksiyonudur ve sütun ve satırlardan oluşur. Yalnızca yapılandırılmış verileri depolar.

OLAP

Çevrimiçi Analitik İşleme Sunucusu (OLAP), çok boyutlu veri modeline dayanmaktadır. Yöneticilerin ve analistlerin bilgiye hızlı, tutarlı ve etkileşimli erişim yoluyla bilgi edinmesine olanak tanır.

NoSQL Veritabanları

Bir NoSQL veritabanı (bazen Yalnızca SQL Değil olarak da adlandırılır), ilişkisel veritabanlarında kullanılan tablo ilişkilerinden başka verileri depolamak ve almak için bir mekanizma sağlayan bir veritabanıdır. Bu veritabanları şemasızdır, kolay çoğaltmayı destekler, basit API'ye sahiptir, sonunda tutarlıdır ve büyük miktarda veriyi (büyük veri) işleyebilir.

Bir NoSQL veritabanının birincil amacı aşağıdakilere sahip olmaktır -

  • Tasarımın sadeliği,
  • Yatay ölçekleme ve
  • Kullanılabilirlik üzerinde daha hassas kontrol.

NoSQL veritabanları, ilişkisel veritabanlarına kıyasla farklı veri yapıları kullanır. NoSQL'de bazı işlemleri daha hızlı hale getirir. Belirli bir NoSQL veritabanının uygunluğu çözmesi gereken soruna bağlıdır. Bu veritabanları hem yapılandırılmış verileri hem de ses dosyaları, video dosyaları, belgeler vb. Gibi yapılandırılmamış verileri depolar. Bu NoSQL veritabanları üç tipte sınıflandırılır ve aşağıda açıklanmıştır.

Key-value Store- Bu veritabanları, verileri anahtar-değer çiftlerinde depolamak için tasarlanmıştır ve bu veritabanları herhangi bir şemaya sahip olmayacaktır. Bu veritabanlarında, her veri değeri indekslenmiş bir anahtardan ve bu anahtar için bir değerden oluşur.

Örnekler - BerkeleyDB, Cassandra, DynamoDB, Riak.

Column Store- Bu veritabanlarında veriler, veri sütunlarında gruplanmış hücrelerde depolanır ve bu sütunlar ayrıca Sütun aileleri halinde gruplandırılır. Bu sütun aileleri herhangi bir sayıda sütun içerebilir.

Örnekler - BigTable, HBase ve HyperTable.

Document Store- Bunlar, "belgelerin" daha karmaşık veriler içerdiği anahtar-değer depolarının temel fikri üzerine geliştirilmiş veritabanlarıdır. Burada her belgeye, belgeyi almak için kullanılan benzersiz bir anahtar atanır. Bunlar, yarı yapılandırılmış veriler olarak da bilinen belge odaklı bilgileri depolamak, almak ve yönetmek için tasarlanmıştır.

Örnekler - CouchDB ve MongoDB.

CouchDB nedir?

CouchDB, Apache yazılım kuruluşu tarafından geliştirilen açık kaynaklı bir veritabanıdır. Odak noktası, web'i kucaklayan kullanım kolaylığıdır. Bir NoSQL belge deposu veritabanıdır.

Verileri (dokümanları) depolamak için JSON, dokümanları dönüştürmek için sorgu dili olarak java betiği, dokümanlara erişmek için api için http protokolü, web tarayıcısı ile indeksleri sorgulamak için kullanır. 2005 yılında yayınlanan bir multi master uygulamasıdır ve 2008 yılında apache projesi haline gelmiştir.

Neden CouchDB?

  • CouchDB, veritabanı ile kolayca iletişim kurmaya yardımcı olan HTTP tabanlı bir REST API'ye sahiptir. Ve HTTP kaynaklarının ve yöntemlerinin (GET, PUT, DELETE) basit yapısının anlaşılması ve kullanılması kolaydır.

  • Verileri esnek belge tabanlı yapıda depoladığımız için verilerin yapısı konusunda endişelenmenize gerek yok.

  • Kullanıcılara, bilgilerin sorgulanmasına, birleştirilmesine ve filtrelenmesine olanak tanıyan güçlü veri eşleme sağlanır.

  • CouchDB, veri tabanları ve makineler arasında verileri kopyalayabileceğiniz, paylaşabileceğiniz ve senkronize edebileceğiniz, kullanımı kolay çoğaltma sağlar.

Veri örneği

  • Veritabanı, CouchDB'deki en dıştaki veri yapısı / kabıdır.

  • Her veritabanı bağımsız belgelerden oluşan bir koleksiyondur.

  • Her belge kendi verilerini ve kendi kendine yeten şemasını korur.

  • Belge meta verileri, veritabanlarının bağlantısı kesilirken oluşan farklılıkları birleştirmeyi mümkün kılan revizyon bilgilerini içerir.

  • CouchDB, yazma sırasında veritabanı alanını kilitleme ihtiyacını ortadan kaldırmak için çoklu sürüm eşzamanlılık kontrolü uygular.

CouchDB'nin Özellikleri: İçeriği Azaltın

Belge saklama

CouchDB bir belge saklama NoSQL veritabanıdır. Belgeleri benzersiz adlarla saklama olanağı sağlar ve ayrıca veritabanı belgelerini okumak ve güncellemek (eklemek, düzenlemek, silmek) için RESTful HTTP API adlı bir API sağlar.

CouchDB'de belgeler birincil veri birimidir ve ayrıca meta verileri de içerir. Belge alanları benzersiz bir şekilde adlandırılır ve çeşitli türlerde değerler içerir (metin, sayı, Boole, listeler vb.) Ve metin boyutu veya öğe sayısı için belirlenmiş bir sınır yoktur.

Belge güncellemeleri (ekleme, düzenleme, silme) Atomicity'yi takip eder, yani bunlar tamamen kaydedilir veya hiç kaydedilmez. Veritabanında kısmen kaydedilmiş veya düzenlenmiş belgeler olmayacaktır.

Json Belge Yapısı

{
   "field" : "value",
   "field" : "value",
   "field" : "value",
}

ACID Özellikleri

CouchDB, özelliklerinden biri olarak ACID özelliklerini içerir.

Tutarlılık - CouchDB'deki veriler bir kez işlendiğinde, bu veriler değiştirilmeyecek veya üzerine yazılmayacaktır. Böylece CouchDB, veritabanı dosyasının her zaman tutarlı bir durumda olmasını sağlar.

Çok Versiyonlu Eş Zamanlılık Kontrolü (MVCC) modeli, CouchDB okumaları tarafından kullanılır, çünkü müşteri, okuma işleminin başından sonuna kadar veritabanının tutarlı bir anlık görüntüsünü görecektir.

Bir belge her güncellendiğinde, CouchDB verileri diske boşaltır ve güncellenmiş veritabanı başlığı, dosyanın ilk 4k'sini oluşturmak için iki ardışık ve aynı parçaya yazılır ve ardından eşzamanlı olarak diske atılır. Yıkama sırasındaki kısmi güncellemeler iptal edilecektir.

Başlık işlenirken hata meydana gelirse, önceki özdeş başlıkların kalan bir kopyası kalır ve önceden kaydedilmiş tüm verilerin tutarlılığını sağlar. Başlık alanı dışında, bir çarpışma veya elektrik kesintisinden sonra tutarlılık kontrolleri veya düzeltmeleri asla gerekli değildir.

Sıkıştırma

Veritabanı dosyasındaki alan belirli bir derecenin üzerinde boşa harcandığında, tüm aktif veriler yeni bir dosyaya kopyalanacaktır (klonlanacaktır). Kopyalama işlemi tamamen tamamlandığında, eski dosya silinecektir. Bütün bunlar sıkıştırma işlemi ile yapılır. Veri tabanı, sıkıştırma sırasında çevrimiçi kalır ve tüm güncellemeler ve okumaların başarıyla tamamlanmasına izin verilir.

Görüntüleme

CouchDB'deki veriler, bireysel örtük yapılarla esnek olan yarı yapılandırılmış belgelerde depolanır, ancak veri depolama ve paylaşımı için basit bir belge modelidir. Verilerimizi birçok farklı şekilde görmek istiyorsak, tablolara ayrılmamış verileri filtrelemek, düzenlemek ve raporlamak için bir yönteme ihtiyacımız var.

Bu sorunu çözmek için CouchDB bir görünüm modeli sağlar. Görünümler, bir veritabanındaki belgeleri toplama ve raporlama yöntemidir ve veritabanı belgelerini toplamak, birleştirmek ve raporlamak için isteğe bağlı olarak oluşturulur. Görünümler dinamik olarak oluşturulduğundan ve temel belgeyi etkilemediğinden, aynı verilerin istediğiniz kadar farklı görünüm temsillerine sahip olabilirsiniz.

Tarih

  • CouchDB, Erlang programlama dilinde yazılmıştır.
  • 2005 yılında Damien Katz tarafından başlatıldı.
  • CouchDB, 2008'de bir Apache projesi oldu.

CouchDB'nin güncel sürümü 1.61'dir.