Изменения документа CAP теорема
Редактировал(а) Alexandr Fokin 2024/01/04 19:49
<
отредактировано Alexandr Fokin
на 2024/01/04 19:49
на 2024/01/04 19:49
отредактировано Alexandr Fokin
на 2023/12/16 14:12
на 2023/12/16 14:12
Изменить комментарий:
Update document after refactoring.
Комментарий
-
Свойства страницы (1 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Содержимое
-
... ... @@ -1,44 +1,28 @@ 1 -|(% style="width:77px" %) |(% style="width:1408px" %)CAP теорема 2 -|(% style="width:77px" %) |(% style="width:1408px" %)Всё, что вы не знали о CAP теореме 3 -https://habr.com/ru/post/328792 4 -|(% style="width:77px" %) |(% style="width:1408px" %)((( 5 -Понятие Split Brain 1 +CAP теорема 2 +\\ 6 6 7 -Ситуация распада кластера узлов на несколько сегментов, в следствии нарушения связи (сети) между сегментами. Каждый сегмент становиться автономным и не может обмениваться данными с другими сегментами. Каждый сегмент принимает решение о продолжение работы. 8 -))) 9 -|(% style="width:77px" %) |(% style="width:1408px" %)((( 10 -|(% style="width:99px" %)Consistency|(% style="width:141px" %)Согласованность данных|(% style="width:1107px" %)В каждый момент времени все узлы возвращают одинаковые наборы данных по одним и тем-же агрегатам. Отсутствие рассинхронизации данных. 11 -|(% style="width:99px" %)Availability|(% style="width:141px" %)Доступность|(% style="width:1107px" %) Каждый узел (не упавший) всегда успешно выполняет запросы (на чтение и запись) 12 -|(% style="width:99px" %)Partition tolerance|(% style="width:141px" %)Устойчивость к разделению|(% style="width:1107px" %)Узлы приложения продолжают работать, даже если связь между ними нарушена и синхронизация невозможна. В таком случае при запросе данных с разных узлов мы можем получить различные агрегаты. 13 -))) 14 -|(% style="width:77px" %) |(% style="width:1408px" %)((( 4 +|(% style="width:164px" %)Понятие Split Brain|(% style="width:1318px" %)Ситуация 1: кластер расположен в одном сетевом сегменте, ноды кластера могут связываться друг с другом. 5 +Ситуация 2: происходит потеря связи, распад на несколько сегментов, которые не могут передавать данные друг другу. 6 + 7 +---- 8 + 9 +|(% style="width:107px" %) |(% style="width:199px" %) |(% style="width:1176px" %) 10 +|(% style="width:107px" %)Consistency|(% style="width:199px" %)Согласованность данных|(% style="width:1176px" %)В каждый момент времени все узлы возвращают одинаковые наборы данных по одним и тем-же агрегатам. Отсутствие рассинхронизации данных. 11 +|(% style="width:107px" %)Availability|(% style="width:199px" %)Доступность|(% style="width:1176px" %) Каждый узел (не упавший) всегда успешно выполняет запросы (на чтение и запись) 12 +|(% style="width:107px" %)Partition tolerance|(% style="width:199px" %)Устойчивость к разделению|(% style="width:1176px" %)Ноды приложения продолжают работать, даже если связь между ними нарушена и синхронизация невозможна. В таком случае при запросе данных с разных нод мы можем получить различные агрегаты. 13 + 14 +---- 15 + 15 15 |(% colspan="2" %)Невозможно в полной мере выполнять все 3 условия. 16 16 |(% style="width:69px" %)AP|(% style="width:1413px" %)В случае невозможности синхронизации данных (Split Brain), все узлы продолжают работу, даже с учетом рассинхронизации данных. 17 17 |(% style="width:69px" %)CP|(% style="width:1413px" %)Все узлы системы перестают работать, если не могу синхронизировать данные между собой. 18 18 |(% style="width:69px" %) |(% style="width:1413px" %)Возможно ситуация, когда разрозненные сегменты имеет механизм принятия решения о том, стоит ли продолжать обрабатывать запросы. 19 19 Например: в случае если исходный кластер состоял из нечетного кол-ва узлов и распался на 2 сегмента, то сегмент, содержащий наибольшую кол-во узлов (относительно исходного кол-ва в кластере), продолжит работу. 20 -))) 21 21 22 22 ---- 23 23 24 -==== Внутренние ссылки: ==== 24 +Всё, что вы не знали о CAP теореме 25 +https://habr.com/ru/post/328792 25 25 26 -====== Дочерние страницы: ====== 27 27 28 -{{children/}} 29 - 30 -====== Обратные ссылки: ====== 31 - 32 -{{velocity}} 33 -#set ($links = $doc.getBacklinks()) 34 -#if ($links.size() > 0) 35 - #foreach ($docname in $links) 36 - #set ($rdoc = $xwiki.getDocument($docname).getTranslatedDocument()) 37 - * [[$escapetool.xml($rdoc.fullName)]] 38 - #end 39 -#else 40 - No back links for this page! 41 -#end 42 -{{/velocity}} 43 - 44 ----- 28 +