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

Илья, можно развёрнуто по последним двум репликам?

5 ответов

17 просмотров

Основная система репликацыи postgres основана на передаче журнала записи блоков (WAL) с ведущего сервера на ведомые. Называется streaming replication. Ведомые серверы имеют очень точную копию базы, включая журналы транзакцый и прочую внутреннюю кухню. На ведомых серверах можно выполнять запросы на чтение. Поддержываются как асинхронные реплики (запись на ведомых можэт проходить с отставанием), так и синхронные, в том числе группы реплик (ведущий ждёт пока хоть один ведомый сервер получит запись до подтверждения коммита транзакцыи). Возможна смена ролей ведущий/ведомый с минимальным даунтаймом, или без такового при поддержке всяких pgpool. Есть развитые средства (внешние, правда) автоматического мониторинга и переключения кластеров -- в первую очередь patroni, но видел что-то на heartbeat и, кажэтся, pgpool (лень искать). В качестве альтэрнативы есть встроенная логическая репликацыя -- отдельные таблицы, обновление по первичному ключу, со своими ограничениями. С другой стороны -- в логической репликацыи допустимы самые разные извращения логического уровня. По-моему, ситуацыя с возможностями репликацыи весьма похожа на MS SQL.

Yevhen-Nedaskivskyi Автор вопроса
Ilya Anfimov
Основная система репликацыи postgres основана на п...

Да, но нет автоматического фейловера и репликация в ПГ однопоточная

Yevhen Nedaskivskyi
Да, но нет автоматического фейловера и репликация ...

Фэйловер есть внешними инструментами. Кстати, в MS SQL кажэтся тожэ внешние демоны для фэйловера используются, не? Что само по себе вообще неважно. Однопоточная -- это, в общем, правда, с другой стороны -- всё что делает репликацыя -- передаёт WAL по сети и выгружает эти блоки на диски. Там не так часто что-то упирается в CPU чтобы нужно было пытаться для этого использоваться несколько ядер.

Yevhen-Nedaskivskyi Автор вопроса
Ilya Anfimov
Фэйловер есть внешними инструментами. Кстати, в MS...

И да и нет. Есть специальная служба в ОС, но СУБД отрабатывает сам фейловер, проверяя целостность и состояние транзакций. Да и ничего дополнительного ставить не нужно. Сугубо связка СУБД + ОС, никаких сторонних програм. А вот по поводу реприкации не согласен. У меня был кластер на 300 баз и 10 ТБ. Около ста разных клиентов с этим всем работало. От 3000 до 1000000 транзакций в секунду. Многопоточность репликации очень сильно решала

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

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

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
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
Карта сайта