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

Все на lua. Есть некоторая функция, согласно которой мы раскидываем

данные на хосты - шарды. Допустим их 3 штуки. Они реплицируют данные на 3 штуки слейвов, которые работают согласно своей настройке. Клиент вызывая шард функцию, знает куда надо писать/читать делает r/w только в мастер (для чего это отдельная история).
Дальше
Нужно добавить с схему новый сервер, меняется настройка слейва и применяется. Что происходит?
1. 3 Мастера начали сливать данные на новые сервера (допустим их уже 4) согласно конфигу слейвов
2. Слейв становится неадекватный, потому что один и тот же пользователь оказывается на разных хостах
3. Зачищаем полностью слейвы (стираем данные) далее, запускаем функцию синхронизации, одновременно идет репликация. Эти процессы идут одновременно и разруливаются приоритетом, чтобы устаревшие данные не затерли новые.
4. Слейвы работаю по новой схеме и полностью адекватны
5. Меняем роли. Слейв становится мастеров, а мастер слейвом
все. Ни секунды остановки

Нет одного роутера, их много, все разруливается конфигами на lua. Достаточно просто рестартануть все проекты на инстансах

4 ответов

11 просмотров

Тут есть проблемка маленькая. Шаг 5 не бывает мгновенным. В кластере ничего мгновенно не бывает. Утверждение про ровно 0 долей секунды не достижимо в принципе, физически.

Евгений- Автор вопроса

я уже говорил про проблему грязных чтений, грязная запись решается репликацией старого мастера на слейв. Кроме того у меня 300+ инстансов обновляются за 0.3-0.7 сек. Это не шард, это вся система

Я ни слова про грязное что-либо не сказал. Я говорю, что утверждение про нулевое время переключения - неправда

Евгений- Автор вопроса

А кто говорил про нулевое?

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

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

коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
А если изначально бот работал так : есть сайт онлайн школы. У каждого ученика свой кабинет. Где он авторизуется по своим данным. И уже в кабинете, на самом сайте делает оплату...
Денис 💡 Фрилансер
13
А что ты вообще делаешь ?
Yesgoter
13
На работе пишем распределенное приложение, у которого сотни, если не тысячи настроек. Конфиги написаны на xml, расположены на разных хостах и должны быть согласованы друг с др...
Aleksandr Druzhinin
5
Всем привет 🙂 Какая-то непонятная проблема у меня с видео, раньше такого не было. Загружаю видео с гугл диска именно в видео mp4 и меняю ссылку как положено вот она: https://d...
Ксюша|Верстка на Тильде|Дизайн 🦥
6
средствами IBX как-то можно выполнить запрос insert ... returning?
Igor
31
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
16
что это и почему оно? executor.start_polling(bot, skip_updates=True, on_startup=on_startup, File "/usr/local/lib/python3.10/dist-packages/aiogram/utils/executor.py", line 4...
𐌍𐌄 ᕓ𐌄𐌓𐌌Ꝋ𐌓𐌄
2
Hi there everyone Is there anyone who have not started hamster bot yet? I need only one, I'll be glad if you do this for me DM if you haven't yet
Mehrshad
53
Подскажите, почему в правом коде с1 дополняется до 8байт, а не до 4?
Sergey
9
Карта сайта