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

Коллеги, добрый вечер Я спрашивал тут пару недель назад, как на

продакшен-базе в 1.5 терабайта включить чексуммы без особого даунтайма
База - мастер да реплика, включение чексумм занимает порядка 40 минут, судя по экспериментам

Подсказали, что можно стопнуть реплику (мастер один нагрузку легко тянет), включить там чексуммы, сделать свитчовер, включить чексуммы на другом сервере, сделать свитчовер ещё раз (нам важно чтобы в итоге мастером осталась прежняя машина, не вдавался почему, но админу верю)

Так вот нюанс в том, что у нас был когда-то неудачный опыт со свитчовером, прилично лет назад, на постгресе вроде 9.6 или около того (сейчас у нас 12.3). А именно - реплика мастером стала, а вот прежний мастер к ней подцепить репликой не удалось. С тех пор не пробовали так делать.
За давностью лет - на что оно там ругалось, не помним конечно.

Сейчас, если свитчовер также не удастся, нам придётся дважды тянуть полтора терабайта по сети, чтобы восстановить репликацию один раз, и потом второй, и это ну такое себе удовольствие.

Так вот хочется подготовиться и сделать таки эти два свитчовера, но чтобы без секса, подскажите как правильно, и где соломки подстелить.

В постгресе много способов репликации, у нас она асинхронная, wal-based (хотя я могу ошибаться или недоговаривать, давно сам не готовил постгрес)

В мастере в конфиге строчки про репликацию такие:
hot_standby = on

На реплике:
hot_standby = on
primary_conninfo = 'host=... port=... user=replication password=...'
promote_trigger_file = '/var/lib/pgsql/12/data/postgresql.trigger'


У нас есть такая дока https://edu.postgrespro.ru/dba3/dba3_05_replica_switchover.pdf

Есть такое сообщение из мейл-листа https://www.postgresql.org/message-id/CANNMO%2BKYuH3Gh7BZp%3DUGXpoos4tBR0AFgoONkqWBrokuJthEug%40mail.gmail.com, где упоминается ещё "убедиться что валы догнались" (как?) и настройка recovery.conf (которого у нас нет)

Достаточно ли доки https://edu.postgrespro.ru/dba3/dba3_05_replica_switchover.pdf для безопасного свитчовера? Или надо что-то ещё проверить / не забыть / и т.п?

Спасибо что дочитали ;)

1 ответов

9 просмотров

> Подсказали, что можно стопнуть реплику (мастер один нагрузку легко тянет), включить там чексуммы Кто подсказал-то (такое я тоже слышал, и с виду оно может и работать, но не делал)? ;) Я к чему — может, у них спросить, как прошло / были ли проблемы? Далее: 1. Стопнуть реплику (мастер один нагрузку легко тянет), включить там чексуммы 2. Сделать свитчовер Вот где-то перед этим шагом реплика, по идее, должна быть "докачена" WAL-ами с primary, нет? 3. включить чексуммы на другом сервере, 4. сделать свитчовер ещё раз И перед этим — тоже, см. выше. > реплика мастером стала, а вот прежний мастер к ней подцепить репликой не удалось timelines разошлись, наверное. Тогда же pg_rewind ещё не было, вроде? > Сейчас, если свитчовер также не удастся, нам придётся дважды тянуть полтора терабайта по сети Не обязательно. Как раз тут можно подумать, как правильно применить pg_rewind, по идее. > где соломки подстелить. А Вы на "урезанных" тестовых кластерах (к примеру, с теми же схемами и почти без данных; или вообще на тестовых базах) потренируйтесь. :) > где упоминается ещё "убедиться что валы догнались" (как?) См. https://www.postgresql.org/docs/current/app-pgcontroldata.html , по идее. > и настройка recovery.conf (которого у нас нет) Это потому, что у Вас v12. > Или надо что-то ещё проверить / не забыть / и т.п? Почитали бы Вы официальную документацию, для начала. ;)

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

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

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Всем привет! вывожу на общей стр дочерние ресурсыв каждом ресурсе галерея, и первая фотка должна выводиться на общей [!DocLister? &prepare=photo !]
Alekso
12
А можно вопрос? Мне сегодня сказали что у меня функция (которая просто заполняет массив значениями) не правильная void Full(double * arr, int n) { for (int i = 0; i < n; i...
† C E †
7
День добрый, подскажите пожалуйста, есть ли какой-то способ сказать ребару не компилировать определённое приложение? Всю доку их перечиатл ничего подобного не нашёл
Кирилл
14
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
10
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Здравствуйте, хочу сделать HelloWorld в консоли Дельфи, но функция API ничего не выводит, что я делаю не так? program Hello; {$APPTYPE CONSOLE} uses System.SysUtils, WinAPI.Wi...
Sergey Vinogradov
20
Карта сайта