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

Добрый день. Был на собесе, задали вопрос с ответом на

который я не уверен:
Допустим есть Service A в трех репликах, который работает с реляционкой.
Как по шагам должна выполнять миграция допустим на добавлением нового поля в схему?
При этом нужно добиться отказоустойчивости и консистентности.

Были идеи запулить нагрузку на реплику, но обычно реплика не имеет актуальных данных и нарушается консистентность
Если же лочить сервисы на запись то нарушается отказоустойчивость

Также одно из вопросов как должен произойти деплой/апдейт сервисов, чтобы они все были консистентны == отдавали одинаковые респонсы, а не так что реплика 1 возвращает респонс с новым полем, а реплика 2 нет

6 ответов

8 просмотров

add column (nullable) deploy app (compatible with nullable) update data drop nullable from column deploy app (dropped compatibility with nullable)

новые поля можно возвращать, важно что бы все изменения были совместимы с предыдущими версиями. новые поля в этом плане норма.

Andrii Dembitskyi
add column (nullable) deploy app (compatible with ...

alter table может устроить даунтайм :)

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

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

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
Подскажите, а есть vault lite или ченить такое?) А то нужен вольт для похода в вольт, но весит он ~500 мб) как-то многовато для парочки запросов ))
Alexandr Orloff
17
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Карта сайта