Репликация — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
м (rollbackEdits.php mass rollback)
 
Строка 1: Строка 1:
{| class="wikitable" align="center" style="color: red; background-color: black; font-size: 56px; width: 800px;"
 
|+
 
|-align="center"
 
|'''НЕТ ВОЙНЕ'''
 
|-style="font-size: 16px;"
 
|
 
24 февраля 2022 года российское руководство во главе с Владимиром Путиным развязало агрессивную войну против Украины. В глазах всего мира это военное преступление совершено от лица всей страны, всех россиян.
 
 
Будучи гражданами Российской Федерации, мы против своей воли оказались ответственными за нарушение международного права, военное вторжение и массовую гибель людей. Чудовищность совершенного преступления не оставляет возможности промолчать или ограничиться пассивным несогласием.
 
 
Мы убеждены в абсолютной ценности человеческой жизни, в незыблемости прав и свобод личности. Режим Путина — угроза этим ценностям. Наша задача — обьединить все силы для сопротивления ей.
 
 
Эту войну начали не россияне, а обезумевший диктатор. И наш гражданский долг — сделать всё, чтобы её остановить.
 
 
''Антивоенный комитет России''
 
|-style="font-size: 16px;"
 
|Распространяйте правду о текущих событиях, оберегайте от пропаганды своих друзей и близких. Изменение общественного восприятия войны - ключ к её завершению.
 
|-style="font-size: 16px;"
 
|[https://meduza.io/ meduza.io], [https://www.youtube.com/c/popularpolitics/videos Популярная политика], [https://novayagazeta.ru/ Новая газета], [https://zona.media/ zona.media], [https://www.youtube.com/c/MackNack/videos Майкл Наки].
 
|}
 
 
 
{{Определение
 
{{Определение
 
|definition =
 
|definition =

Текущая версия на 19:36, 4 сентября 2022

Определение:
Репликация — это поддержание одинаковых данных на нескольких узлах распределенной системы.


Реализация репликации

Типы репликации

  • Синхронная — гарантирует одинаковое состояние реплик, требует введения распределенных транзакций.
  • Асинхронная — допускает задержки репликации.

Репликация основной копией

Репликация с основной копией

Есть одна главная копия данных, запросы на запись поступают только туда, а затем реплицируются на все остальные копии. За согласованность изменений отвечает главная копия. Если изменения приводят к несогласованному состоянию, то транзакция откатывается. Запросы на чтение могут быть обработаны любой репликой. Такая реализация эффективна, если количество записей сильно меньше количества запросов чтения.

Симметричная репликация

Симметричная репликация

Чтение и запись могут быть обработаны любой копией. При необходимости реплики могут работать автономно.

Преимущества:

  • Запросы можно отправлять на географически ближайшую реплику

Недостатки:

  • Необходимо обрабатывать случай записей с разных копий, которые конфликтуют при репликации.
  • При выходе из строя любой реплики, состояние системы не согласовано и данные потеряны.

Таким образом, синхронная репликация сложна и малонадежна. В реальности распределенные базы данных решают эту проблему лучше.

Рассылка изменений

Информация обо всех сделанных изменениях содержится в журнале транзакций. Репликация достигается за счёт рассылки протоколов транзакций. Это можно сделать двумя способами:

Репликация операторов

  • На реплике выполняются те же операторы
  • Пересылается малый объем данных
  • Операторы должны быть детерминированны
  • Необходимо учитывать взаимный порядок выполнения транзакций.

Репликация записей

  • Пересылается информация об изменении записей
  • Результат детерминирован
  • Вынужденно пересылается большое количество записей

Применения репликации

Вертикальное масштабирование

Большое количество чтений, малое количество записей. Схема репликации с одной копией. Примеры: web-сервера, erp-системы.

Горизонтальное масштабирование

Большое количество локальный операций (например, по критерию географической распределенности). Реплика отвечает за свой набор данных, т.е. по запросу всегда можно определить нужную реплику. Применение: географическая распределенность, независимость по данным, непостоянная связь.

Повышение доступности

Ассиметричная схема репликации позволяет менять основную реплику не останавливая работу системы.

Резервное копирование

Ассиметричная схема.

  • Для получения резервной копии добавим специальную реплику, которая будет синхронизирована с основной.
  • В момент взятия резервной копии отключаем синхронизацию.
  • Чтобы сделать следующую резервную копию, синхронизация снова включается.
  • Реплика получает все изменения, сделанные с момента отключения.

Преобразование данных

Ассиметричная схема репликации позволяет добавлять специальные реплики, которые занимаются обработкой данных. Периодически синхронизуясь, такая реплика преобразовывает данные, например: изменение формата хранения, консолидация данных, унификация данных.

Литература