Изменения документа CAP теорема

Редактировал(а) Alexandr Fokin 2024/01/04 19:49

<
От версии < 2.7 >
отредактировано Alexandr Fokin
на 2023/12/16 14:12
К версии < 2.8
отредактировано Alexandr Fokin
на 2024/01/04 19:49
Изменить комментарий: К данной версии нет комментариев

Комментарий

Подробности

Свойства страницы
Содержимое
... ... @@ -1,28 +1,44 @@
1 -CAP теорема
2 -\\
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
3 3  
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 -
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" %)(((
16 16  |(% colspan="2" %)Невозможно в полной мере выполнять все 3 условия.
17 17  |(% style="width:69px" %)AP|(% style="width:1413px" %)В случае невозможности синхронизации данных (Split Brain), все узлы продолжают работу, даже с учетом рассинхронизации данных.
18 18  |(% style="width:69px" %)CP|(% style="width:1413px" %)Все узлы системы перестают работать, если не могу синхронизировать данные между собой.
19 19  |(% style="width:69px" %) |(% style="width:1413px" %)Возможно ситуация, когда разрозненные сегменты имеет механизм принятия решения о том, стоит ли продолжать обрабатывать запросы.
20 20  Например: в случае если исходный кластер состоял из нечетного кол-ва узлов и распался на 2 сегмента, то сегмент, содержащий наибольшую кол-во узлов (относительно исходного кол-ва в кластере), продолжит работу.
20 +)))
21 21  
22 22  ----
23 23  
24 -Всё, что вы не знали о CAP теореме
25 -https://habr.com/ru/post/328792
24 +==== Внутренние ссылки: ====
26 26  
26 +====== Дочерние страницы: ======
27 27  
28 -
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 +----