41 lines
2.5 KiB
Markdown
41 lines
2.5 KiB
Markdown
---
|
||
aliases:
|
||
tags:
|
||
- maturity/🌱
|
||
date:
|
||
- - 2024-06-05
|
||
zero-link:
|
||
- "[[../../../meta/zero/00 HighLoad|00 HighLoad]]"
|
||
parents:
|
||
- "[[Репликация БД]]"
|
||
linked:
|
||
---
|
||
Работает как [Репликация master-master](Репликация%20master-master.md), но при количестве узлов больше 2
|
||
|
||
- Все транзакции чтения и записи фиксируются только после того, как они были одобрены группой.
|
||
- Read-only транзакции не требуют координации внутри группы и фиксируются немедленно
|
||
- Групповая репликация - eventual consistency система
|
||
|
||
![](../../../meta/files/images/Pasted%20image%2020240605091036.png)
|
||
|
||
## Консенсус
|
||
- Когда транзакция read-write готова к фиксации на исходном сервере, сервер атомарно передает значения записи (строки, которые были изменены) и соответствующий набор записи (уникальные идентификаторы строк, которые были обновлены).
|
||
- Транзакция отправляется через атомарную broadcast рассылку, транзакцию получают либо все серверы в группе, либо ни один.
|
||
- Если они его получат, то все они получат его в том же порядке относительно других транзакций, которые были отправлены ранее.
|
||
|
||
Таким образом, все серверы получают один и тот же набор транзакций в одном и том же порядке, и для транзакций устанавливается глобальный общий порядок.
|
||
|
||
## Дополнительные материалы
|
||
- [MySQL 20.1.1.2 Group Replication](https://dev.mysql.com/doc/refman/8.0/en/group-replication-summary.html)
|
||
***
|
||
## Мета информация
|
||
**Область**:: [[../../../meta/zero/00 HighLoad|00 HighLoad]]
|
||
**Родитель**:: [[Репликация БД]]
|
||
**Источник**::
|
||
**Автор**::
|
||
**Создана**:: [[2024-06-05]]
|
||
### Дополнительные материалы
|
||
-
|
||
### Дочерние заметки
|
||
<!-- QueryToSerialize: LIST FROM [[]] WHERE contains(Родитель, this.file.link) or contains(parents, this.file.link) -->
|