Nihai tutarlılık - Eventual consistency

Nihai tutarlılık bir tutarlılık modeli kullanılan dağıtılmış hesaplama başarmak yüksek kullanılabilirlik Bu, belirli bir veri öğesine yeni güncelleme yapılmazsa, sonunda o öğeye yapılan tüm erişimlerin son güncellenen değeri döndüreceğini gayri resmi olarak garanti eder.[1] Nihai tutarlılık, aynı zamanda iyimser çoğaltma,[2] yaygın olarak dağıtılmış sistemlerde konuşlandırılır ve kökenleri erken mobil bilgi işlem projelerine dayanır.[3] Nihai tutarlılığı elde eden bir sistemin genellikle sahip olduğu söylenir Bütünleşikveya elde edildi kopya yakınsaması.[4] Nihai tutarlılık zayıf bir garantidir - en güçlü modeller, örneğin doğrusallaştırılabilirlik önemsiz bir şekilde nihayetinde tutarlıdır, ancak yalnızca nihayetinde tutarlı olan bir sistem genellikle bu daha güçlü kısıtlamaları yerine getirmez.

Sonunda tutarlı hizmetler genellikle BASE (Baynı şekilde Birmevcut Sçoğu durumda Eventual tutarlılık) anlambilim, gelenekselin aksine ASİT (Birtomicity Ckararlılık, bençözüm Duygulanabilirlik) garantiler.[5][6] Kimyada BASE, kısaltmanın hatırlanmasına yardımcı olan ACID ile zıttır.[7] Aynı kaynağa göre, bunlar BASE'deki her terimin kabaca tanımlarıdır:

  • (B) aynı şekilde (A) kullanılabilir: temel okuma ve yazma işlemleri mümkün olduğunca (bir veritabanı kümesinin tüm düğümlerini kullanarak) kullanılabilir, ancak herhangi bir tutarlılık garantisi olmadan (çatışmalar uzlaştırıldıktan sonra yazma devam etmeyebilir, okuma en son yazıyı alamayabilir)
  • (S) genellikle durum: tutarlılık garantileri olmazsa, bir süre sonra, henüz yakınlaşmamış olabileceğinden, durumu tanıma olasılığımız yalnızca bir miktar olur.
  • (E) ventilasyon tutarlı: Sistem çalışıyorsa ve herhangi bir girdi setinden sonra yeterince uzun süre beklersek, eninde sonunda veritabanının durumunun ne olduğunu öğrenebiliriz ve böylece daha sonraki okumalar beklentilerimizle tutarlı olacaktır.

Nihai tutarlılık bazen eleştirilir[8] dağıtık yazılım uygulamalarının karmaşıklığını artırarak. Bunun nedeni kısmen nihai tutarlılığın tamamen canlılık garanti (okur sonunda aynı değeri döndürür) ve yapmaz Emniyet garantiler: Sonunda tutarlı bir sistem, yakınsamadan önce herhangi bir değeri döndürebilir.

Çatışma çözümü

Kopya yakınsamasını sağlamak için, bir sistem, dağıtılmış verilerin birden çok kopyası arasındaki farklılıkları uzlaştırmalıdır. Bu iki bölümden oluşur:

  • sunucular arasında veri sürümlerini veya güncellemelerini değiştirmek (genellikle anti-entropi);[9] ve
  • eşzamanlı güncellemeler gerçekleştiğinde uygun bir son durum seçme, çağrılır mutabakat.

Mutabakat için en uygun yaklaşım uygulamaya bağlıdır. Yaygın bir yaklaşım "son yazar kazanır".[1] Diğeri, kullanıcı tanımlı bir çakışma işleyicisini çağırmaktır.[4] Zaman damgaları ve vektör saatler genellikle güncellemeler arasındaki eşzamanlılığı tespit etmek için kullanılır. "ilk yazar kazanır" nerede "son yazar kazanır" kabul edilemez.[10]

Eşzamanlı yazma işlemlerinin mutabakatı, bir sonraki okumadan önce yapılmalıdır ve farklı anlarda planlanabilir:[3][11]

  • Okuma onarımı: Bir okuma bir tutarsızlık bulduğunda düzeltme yapılır. Bu, okuma işlemini yavaşlatır.
  • Yazma onarımı: Düzeltme, bir tutarsızlık bulunursa yazma işlemi sırasında gerçekleşir ve yazma işlemini yavaşlatır.
  • Eşzamansız onarım: Düzeltme, okuma veya yazma işleminin parçası değildir.

Güçlü nihai tutarlılık

Nihai tutarlılık sadece bir canlılık garanti (güncellemeler sonunda gözlemlenecektir), güçlü nihai tutarlılık (SEC) ekler Emniyet aynı (sırasız) güncelleme setini alan herhangi iki düğümün aynı durumda olacağını garanti eder. Dahası, sistem monoton, uygulama asla geri dönüşlere maruz kalmaz. Çakışmasız çoğaltılmış veri türleri SEC sağlamaya yönelik yaygın bir yaklaşımdır.[12]

Ayrıca bakınız

Referanslar

  1. ^ a b Vogels, W. (2009). "Sonunda tutarlı". ACM'nin iletişimi. 52: 40. doi:10.1145/1435417.1435432.
  2. ^ Vogels, W. (2008). "Sonunda Tutarlı". Kuyruk. 6 (6): 14. doi:10.1145/1466443.1466448.
  3. ^ a b Terry, D. B .; Theimer, M. M .; Petersen, K .; Demers, A. J .; Spreitzer, M. J .; Hauser, C.H. (1995). "Zayıf bağlantılı çoğaltılmış bir depolama sistemi olan Bayou'daki güncelleme çakışmalarını yönetme". İşletim sistemleri ilkeleri üzerine on beşinci ACM sempozyumu bildirileri - SOSP '95. s. 172. CiteSeerX  10.1.1.12.7323. doi:10.1145/224056.224070. ISBN  978-0897917155.
  4. ^ a b Petersen, K .; Spreitzer, M. J .; Terry, D. B .; Theimer, M. M .; Demers, A.J. (1997). "Zayıf düzeyde tutarlı çoğaltma için esnek güncelleme yayılımı". ACM SIGOPS İşletim Sistemleri İncelemesi. 31 (5): 288. CiteSeerX  10.1.1.17.555. doi:10.1145/269005.266711.
  5. ^ Pritchett, D. (2008). "Baz: Bir Asit Alternatifi". Kuyruk. 6 (3): 48–55. doi:10.1145/1394127.1394128.
  6. ^ Bailis, P .; Ghodsi, A. (2013). "Bugünkü Nihai Tutarlılık: Sınırlamalar, Uzantılar ve Ötesi". Kuyruk. 11 (3): 20. doi:10.1145/2460276.2462076.
  7. ^ Karaca, Charles. "ASİT - BAZ: Veritabanı İşlem İşleminde Değişen pH". VERİLER. DATAVERSITY Education, LLC. Alındı 29 Ağustos 2019.
  8. ^ HYaniv Pessach (2013), Dağıtılmış Depolama (Dağıtılmış Depolama: Kavramlar, Algoritmalar ve Uygulamalar ed.), Amazon, OL  25423189M, Nihai Tutarlılığı kullanan sistemler, sistem yükünün azalmasına ve sistem kullanılabilirliğinin artmasına neden olur, ancak kullanıcılar ve geliştiriciler için artan bilişsel karmaşıklık ile sonuçlanır
  9. ^ Demers, A .; Greene, D .; Hauser, C .; İrlandalı, W .; Larson, J. (1987). "Çoğaltılmış veritabanı bakımı için salgın algoritmalar". Dağıtık hesaplama Prensipleri üzerine altıncı yıllık ACM Sempozyumu Bildirileri - PODC '87. s. 1. doi:10.1145/41840.41841. ISBN  978-0-89791-239-6.
  10. ^ Rockford Lhotka."Eşzamanlılık teknikleri".2003.
  11. ^ Olivier Mallassi (2010-06-09). "Cassandra ile oynayalım… (Bölüm 1/3)". http://blog.octo.com/en/: OCTO Görüşmeleri!. Alındı 2011-03-23. Elbette, belirli bir zamanda, her düğümün kendi veri sürümüne sahip olma ihtimali yüksektir. Uyuşmazlık çözümü okuma istekleri sırasında yapılır (okuma-onarım olarak adlandırılır) ve Cassandra'nın mevcut sürümü bir Vektör Saat çakışma çözme mekanizması [sic] sağlamaz (sürüm 0.7'de olmalıdır). Çatışma çözümü, zaman damgasına dayanır (satırı veya sütunu eklediğinizde ayarlanan): daha yüksek zaman damgası kazanır [s] ve verileri okuduğunuz düğüm [from] bundan sorumludur. Bu önemli bir noktadır çünkü zaman damgası müşteri tarafından sütun eklendiği anda belirtilir. Bu nedenle, tüm Cassandra müşterilerinin [sic] 'nin senkronize edilmesi gerekir ...
  12. ^ Shapiro, Marc; Preguiça, Nuno; Baquero, Carlos; Zawirski, Marek (2011-10-10). "Çakışmasız çoğaltılmış veri türleri". 13. Uluslararası Stabilizasyon, Güvenlik ve Dağıtılmış Sistemlerin Güvenliği Konferansı SSS'11 Bildirileri. Springer-Verlag Berlin, Heidelberg: 386-400.