Couchbase Server
Couchbase Server, Membase olarak bilinen, açık kaynak ve NoSQL tabanlı doküman şeklinde verileri tutan, etkileşimli uygulamalar için bir geliştirilmiş veritabanı türüdür. Bu uygulamalar genelde aynı anda birçok kullanıcının kullandığı servisler gibi olmalıdır. Bu uygulamalarda eşzamanlı olarak birden çok veri işlenir, depolanır, güncellenir, çekilir. Bu ihtiyaçlar karşısında Couchbase kolay ölçeklenebilir anahtar-değer ya da doküman olarak erişilebilen, düşük gecikme zamanı ve yüksek kalıcı verimliliği olan bir veritabanıdır. Couchbase bir makine üzerindeki büyük ölçekli veriler için küme(cluster) olarak tasarlanmıştır.
Couchbase,[1] memcached ile alışıldık olduğu gibi kablo üzerinde bütünlük sağlar ama disk kalıcılığı, veri kopyalaması, canlı küme yeniden yapılandırması, verileri yeniden dengeleme (rebalancing) gibi özellikler için tasarlanmıştır.
AOL, Cisco, Concur, LinkedIn, Orbitz, Salesforce.com, Shuffle Master, Zynga, NHN Corporation gibi şirketler ve diğer yüzlercesi etkileşimli web uygulamaları ve mobil uygulamalar için CouchBase'i kullanırlar.
Eric Brewer'in deyimiyle CAP teorem, Couchbase bir CP tipi sistemdir.
Ürün Tarihi
değiştirMembase memcached projesinin birkaç lideri tarafından geliştirildi. Bu liderlerler NorthScale adında bir şirket kurmuşlardı, anahtar-değer depolamanın basitliği, hız, memcahed ölçeklenebilirliği gibi özellikleri geliştirdiler, ama aynı zamanda depolama, kalıcılık ve veritabanın sorgu yetenekleri gibi özellikleri de sağladılar. Orijinal membase kaynak kodu NorthScale'den katkı aldı ve proje ortak sponsorları 2010 yılında Zynga ve NHN oldu.
8 şubat 2011'de Membase proje kurucuları ve Membase, Anonim şirket CouchOne (CouchDB arkasındaki birçok temel oyuncusuyla bir şirket) olarak birleştirilip projelerin ilişkilendirilmesiyle duyuruldu. Bu birleştirilmiş şirkete ise CouchBase denildi. Aralık 2012'de CouchBase Sunucusunun 1.8 sürümü çıkarıldı. CouchBase 2.0 sürümü Json dokümanları depolama, indeksleme ve sorgulama, artırılmış Map Reduce özelliği ve çapraz veri merkezi kopyalama gibi yeni özellikleriyle çıkarıldı.
Yüksek Seviyeli Mimari
değiştirHer CouchBase düğümü veri yönetimi ve küme yönetimi bileşenlerinin mimarisi olarak birbirinin aynısıdır.
Küme Yöneticisi
değiştirKüme yöneticisi bir CouchBasedeki tüm sunucuları yapılandırır ve davranışlarını denetler. Düğümlerin davranışlarını kopyalama akış yönetimi ve yeniden dengelendirme (rebalancing) gibi işlemleri de yapılandırır ve denetler. Küme yöneticisi aynı zamanda toplama ölçümü ve kümeler için olan fonksiyonlarda fikir birliği sağlar ve bir RESTful küme yönetici API'sidir. Küme yöneticisi Erlang/OTP üstünde inşa edilmiştir.
Kopyalama ve Yerine Çalışma
değiştir- Çoklu model kopyalama desteği: master-slave kopyalamayı destekleyen mimari altında makineden(peer-to-peer) makineye kopyalama sağlanır.
- Yapılandırılabilir kopyalama sayacı: Mevcut gereksinimlerle kaynak kullanımını dengeler.
- Yüksek hızlı yerine çalışma: Hızlı yerine çalışma madde tabanlı istekler üzerinden çoğaltılır.
Veri Yöneticisi
değiştirVeri yöneticisi depolama ve doküman alma gibi çeşitli veri işlemleriden sorumludur.
- İstemci yazmayı onayladıktan sonra veriler diske eşzamanlı olmayarak yazılırlar. 1.7 sürümü ve sonrasında, uygulamalar verileri birden fazla sunucuda eşzamanlı olarak sağlayabilirler, ancak 1.7 sürümünde veriler disklere hala eşzamanlı olmayarak yazılır.
Veri Biçimi
değiştirCouchbase'de bir doküman veri işlemenin çok temel bir birimidir. Dokümanlar Json doküman biçiminde önceden tanımlı şemalar olmadan depolanır.
Nesne Yönetilen Önbellek
değiştirCouchbase sunucusu inşa edilmiş çoklu iş parçacıklı nesne yönetilen önbellek içerir. Bu memcached uyumlu API'lerde veri ayarlama, veri çekme, silme, ekleme, gibi işlemleri yapar. Nesne Yönetilen Önbellek Couchbase sunucusu inşa edilmiş çoklu iş parçacıklı nesne yönetilen önbellek içerir. Bu memcached uyumlu API'lerde veri ayarlama, veri çekme, silme, ekleme, gibi işlemleri yapar
Depolama Motoru Tasarımı
değiştirCouchbase veri bozulmasına bağışıklık olarak kuyruk ekleme tasarımına sahiptir. Veriler dosyalarda tutulur, Couchbase veri güncellemesi için pek çok sıralı yazma işlemini yapar ve I/O diskleri için iyileştirilmiş bir erişim tasarımı sağlar.
Performans
değiştirCisco Couchbase'in verimliliğini ve gecikme zamanını ölçen bir referans yayınladı. Diğer performans referansı ise Altoros tarafından verildi, bu referansta diğer NoSQL veritabanları ve Couchbase'in veritabanı çözümlemeleri karşılaştırıldı.
Lisans ve Destekleme
değiştirCouchbase sunucusu bir açık kaynak projedir ve iki çeşidi mevcuttur: Topluluk Sürümü hatalardan olmadan önceki hatalar Açık Kaynak olarak son hataları kapatılmamış ve Kurumsal Sürümü ticari işlemler için mevcuttur.
Kaynakça
değiştir- ^ "Couchbase". 24 Ağustos 2013 tarihinde kaynağından arşivlendi. Erişim tarihi: 9 Eylül 2013.