Případná konzistence - Eventual consistency
tento článek může být pro většinu čtenářů příliš technická na to, aby je pochopili. Prosím pomozte to vylepšit na aby to bylo srozumitelné pro neodborníky, aniž by byly odstraněny technické podrobnosti. (Ledna 2017) (Zjistěte, jak a kdy odstranit tuto zprávu šablony) |
Případná konzistence je model konzistence použito v distribuované výpočty dosáhnout vysoká dostupnost která neformálně zaručuje, že pokud nebudou u dané datové položky provedeny žádné nové aktualizace, nakonec všechny přístupy k této položce vrátí poslední aktualizovanou hodnotu.[1] Případná konzistence, také nazývaná optimistická replikace,[2] je široce nasazen v distribuovaných systémech a má původ v počátcích projektů mobilních počítačů.[3] Často se říká, že systém, který dosáhl případné konzistence konvergovanénebo dosažené konvergence replik.[4] Případná konzistence je slabou zárukou - podobně jako většina silnějších modelů linearizovatelnost jsou triviálně nakonec konzistentní, ale systém, který je pouze nakonec konzistentní, obvykle tato silnější omezení nesplňuje.
Nakonec konzistentní služby jsou často klasifikovány jako služby poskytující ZÁKLAD (Basically Ak dispozici, Sčasto stát, Eventrální konzistence) sémantika, na rozdíl od tradiční KYSELINA (Atomicita, Consistency, Jásolace, Dnaléhavost) záruky.[5][6] V chemii je BASE protikladem KYSELINY, což pomáhá zapamatovat si zkratku.[7] Podle stejného zdroje se jedná o hrubé definice každého výrazu v BASE:
- (B) asically (A) vailable: basic reading and write operations are available as much as possible (using all nodes of a database cluster), but without any kind of consistent warranty (the write may not persist after conflict are reconcied, the read nemusí dostat nejnovější zápis)
- (S) častý stav: bez záruk konzistence máme po určité době jen určitou pravděpodobnost, že tento stát poznáme, protože se možná ještě nespojil
- (E) ventually consistent: If the system is working and we wait dosť dlouho po jakékoli dané sadě vstupů, budeme nakonec schopni vědět, jaký je stav databáze, a tak jakékoli další čtení bude v souladu s našimi očekáváními
Někdy je kritizována případná důslednost[8] jako zvyšování složitosti distribuovaných softwarových aplikací. Je to částečně proto, že případná konzistence je čistě a živost záruka (čtení nakonec vrátí stejnou hodnotu) a nedělá bezpečnost záruky: nakonec konzistentní systém může vrátit jakoukoli hodnotu, než dojde ke konvergenci.
Řešení konfliktů
Aby byla zajištěna konvergence replik, musí systém sladit rozdíly mezi více kopiemi distribuovaných dat. Skládá se ze dvou částí:
- výměna verzí nebo aktualizací dat mezi servery (často označovaná jako anti-entropie);[9] a
- výběr vhodného konečného stavu, když dojde k souběžným aktualizacím, tzv smíření.
Nejvhodnější přístup k usmíření závisí na aplikaci. Rozšířený přístup je „vyhrává poslední autor“.[1] Další možností je vyvolat obsluhu konfliktu specifikovanou uživatelem.[4] Časová razítka a vektorové hodiny se často používají k detekci souběžnosti mezi aktualizacemi. Někteří lidé používají „první spisovatel vyhrává“ v situacích, kdy „vyhrává poslední autor“ je nepřijatelné.[10]
Ke sladění souběžných zápisů musí dojít někdy před dalším čtením a lze jej naplánovat v různých okamžicích:[3][11]
- Oprava čtení: Oprava se provede, když čtení zjistí nekonzistenci. To zpomaluje operaci čtení.
- Oprava zápisu: Oprava proběhne během operace zápisu, pokud byla nalezena nekonzistence, což zpomaluje operaci zápisu.
- Asynchronní oprava: Oprava není součástí operace čtení nebo zápisu.
Silná případná konzistence
Zatímco případná konzistence je pouze a živost záruka (aktualizace budou případně pozorovány), silná případná konzistence (SEK) přidává bezpečnost zaručit, že jakékoli dva uzly, které obdržely stejnou (neuspořádanou) sadu aktualizací, budou ve stejném stavu. Pokud navíc systém je monotóní, aplikace nikdy nebude trpět odvoláním. Bezkonfliktní replikované datové typy jsou společným přístupem k zajištění SEC.[12]
Viz také
Reference
- ^ A b Vogels, W. (2009). „Nakonec konzistentní“. Komunikace ACM. 52: 40. doi:10.1145/1435417.1435432.
- ^ Vogels, W. (2008). „Nakonec konzistentní“. Fronta. 6 (6): 14. doi:10.1145/1466443.1466448.
- ^ A b Terry, D. B .; Theimer, M. M .; Petersen, K .; Demers, A. J .; Spreitzer, M. J .; Hauser, C. H. (1995). "Správa konfliktů aktualizací v Bayou, slabě připojeném replikovaném úložném systému". Sborník z patnáctého sympózia ACM o principech operačních systémů - SOSP '95. str. 172. CiteSeerX 10.1.1.12.7323. doi:10.1145/224056.224070. ISBN 978-0897917155.
- ^ A b Petersen, K .; Spreitzer, M. J .; Terry, D. B .; Theimer, M. M .; Demers, A. J. (1997). "Flexibilní šíření aktualizací pro slabě konzistentní replikaci". Recenze operačních systémů ACM SIGOPS. 31 (5): 288. CiteSeerX 10.1.1.17.555. doi:10.1145/269005.266711.
- ^ Pritchett, D. (2008). „Base: Acid Alternative“. Fronta. 6 (3): 48–55. doi:10.1145/1394127.1394128.
- ^ Bailis, P .; Ghodsi, A. (2013). „Eventual Consistency Today: Limitations, Extensions, and Beyond“. Fronta. 11 (3): 20. doi:10.1145/2460276.2462076.
- ^ Roe, Charles. „ACID vs. BASE: The Shifting pH of Database Transaction Processing“. DATAVERZITA. DATAVERSITY Education, LLC. Citováno 29. srpna 2019.
- ^ HYaniv Pessach (2013), Distribuované úložiště (Distributed Storage: Concepts, Algorithms, and Implementations ed.), Amazon, OL 25423189M,
Systémy využívající eventuální konzistenci vedou ke snížení zatížení systému a zvýšení dostupnosti systému, ale mají za následek zvýšenou kognitivní složitost pro uživatele a vývojáře
- ^ Demers, A .; Greene, D .; Hauser, C .; Irish, W .; Larson, J. (1987). Msgstr "Epidemické algoritmy pro údržbu replikované databáze". Sborník příspěvků ze šestého ročníku ACM Symposium on Principles of distributed computing - PODC '87. str. 1. doi:10.1145/41840.41841. ISBN 978-0-89791-239-6.
- ^ Rockford Lhotka.„Techniky souběžnosti“.2003.
- ^ Olivier Mallassi (09.06.2010). „Pojďme si hrát s Cassandrou… (část 1/3)“. http://blog.octo.com/en/: OCTO Talks!. Citováno 2011-03-23.
Samozřejmě v danou dobu je velká šance, že každý uzel má svou vlastní verzi dat. Řešení konfliktů se provádí během požadavků na čtení (tzv. Read-repair) a aktuální verze Cassandry neposkytuje mechanismy řešení konfliktů Vector Clock [sic] (mělo by být k dispozici ve verzi 0.7). Řešení konfliktů je tedy založeno na časovém razítku (nastaveném při vložení řádku nebo sloupce): je za to vyšší časová známka s výhrou [s] a uzel, ze kterého čtete data [od]. Toto je důležitý bod, protože časové razítko určuje klient v okamžiku vložení sloupce. Proto je třeba synchronizovat všechny klienty Cassandry [sic] ...
- ^ Shapiro, Marc; Preguiça, Nuno; Baquero, Carlos; Zawirski, Marek (10.10.2011). "Replikované datové typy bez konfliktů". Sborník SSS'11 ze 13. mezinárodní konference o stabilizaci, bezpečnosti a zabezpečení distribuovaných systémů. Springer-Verlag Berlin, Heidelberg: 386–400.