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

Привет. 2 сервера MySql 5.7.35 - master и slave. В

конфигах дополнительно прописан expire_logs_days = 7 (как я вычитал в мануале скуля данный параметр определяет сколько времени будет храниться бинлог со всеми изменениями мастера). Ок, сервер с репликой уходит в даун на 10 минут. Стартует, show slave status с ошибкой Could not execute Update_rows event on table XXX. stop slave, reset slave, забираю новый master status с мастера, привязываю реплику, старт и таже самая ошибка. Без использования sql_slave_skip_counter как Вы чините подобное?
Диагностировать ошибку репликации по сообщению почти нереально, но мб есть какой-то совет. Спасибо.

2 ответов

17 просмотров

берешь из slave status файл/позицию из релей лога. парсишь файл. находишь на чем падает. дальше смотришь на ошибку и на те данные что лежат в таблице (этой или родительской, если проблема с fk). меняешь данные. стартуешь реплику. будьте внимательны, если у вас транзакция состоит из нескольких запросов. будьте особенно внимательны если у вас master-master, так как все ваши изменения пойдут в бинлог и будут применены на другом сервере. то, что сделали вы мне не совсем понятно. если вы ресетнули слейв и взяли какую-то другую позицию с мастера, то у вас реплика неконсистента, если хотя бы одна транзакция была применена после выполнения change master to/start slave. тут я могу предложить посмотреть логи и убедиться, что ничего не накатилось. если не накатилось, то ищите там же первую позицию на которой все свалилось, делайте change master/start slave и чините как описано ранее. если же что-то накатилось, то у вас есть два пути полный ребилд реплики или опять же change master to/start slave и чинить реплику, а потом уже pt-table-checksum/sync, чтобы убрать несоответствия. если вы не будете ребилдить реплику с нуля, то я бы порекомендовал бы в любом случае проверить консистентность. и если вам важна консистентность данных не применяйте skip_slave_counter. ну и в финале совет читать доки прежде чем что-то запускать/менять.

zil_spb- Автор вопроса
svart
берешь из slave status файл/позицию из релей лога...

угу, будет полный ребилд реплики. спс.

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

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

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
А в каком формате фреймы? Сам формат сейчас придумываешь, или что-то готовое нужно распарсить?
Okhsunrog
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Карта сайта