184 похожих чатов

Подскажите плз, как будет себя вести репликация в след случае: 1)

есть таблица T (ReplecatedMergeTree) и две реплики R1, R2, причем R1 содержит самые свежие изменния, а R2 отстает на 1 parts
2) R1 падает,в ZK есть событие, что R1 имеет новый parts, но R2 теперь не может подятнуть оттуда данные
3) идет запись в Т, и запрос на запись попадает в R2

Что дальше произойдет?
1) п.3 вообще не сработает, т.к. R2 отстала
2) R2 запишет новый parts, а старый parts потом подтянется, когда поднимется R1
3) R2 запишет новый parts, а старый parts пропадет
4) что-то еще

3 ответов

11 просмотров

2 это eventual consistency, когда-то в будущем мы синхронизируемся

если запрос содержит новый батч то данные вставятся в R2 и пойдет второй вариант, но с оговорками, когда R1 поднимется, это надеюсь случиться не раньше чем почистится очередь репликации максимальная длинна которой max_replicated_logs_to_keep - 1000 то все восстановится из R1... если позже, то ваш парт попадет в system.detached_parts только я не помню с каким reason если запрос содержит старый батч (повторная запись тех же самых строк) контрольная сумма которого есть в ZK и соответсвует replicated_deduplication_window - 100, replicated_deduplication_window_seconds - 1 week, то он проигнорится молча на R2, но восстановится когда R1 вернется в строй. с оговорками которые я привел выше

Похожие вопросы

Обсуждают сегодня

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Заметил в ghci 9.4.8: > :t (<*>) @((->)_) (<*>) @((->)_) :: (w -> (a -> b)) -> (w -> a) -> w -> b Разве не должно (w -> (a -> b)) быть записано как (w -> a -> b)? Это баг, ил...
Михаил
13
Any electron dev here?
Sayanth Tezro
12
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
так это может кто что знает или использует что-то как макбук только не макбук? на 13…14 дюймов
Michael
9
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
did you mean this? if yes no you don't need it. just need a ui for handle process with ui and some terminal code. you don't want to re create adb your self you just want add u...
Mr Thieves
7
Карта сайта