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

Хочу ускорить логическую репликацию с мастера на слейв, разбив ее

на 2 публикации. Но как избежать волны инконсистенси в самых свежих данных, если мы джойним таблицы из двух разных подписок?

На подписчике вообще не хранится оффсет в вал, и похоже нельзя просто отсечь слишком новые туплы после xid самой старой подписки, во время чтения.

Нужно что-то свое костылить?

8 ответов

9 просмотров

А почему две репликации будут быстрее одной? Если правильно помню, работа с wal однопоточная

blkmrkt- Автор вопроса
Valery
А почему две репликации будут быстрее одной? Если ...

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

blkmrkt
Если таблицы логически не связаны, то есть знаем ч...

Но wal пишется в один поток, откуда ускорение?

blkmrkt- Автор вопроса
Valery
Но wal пишется в один поток, откуда ускорение?

Записывать не медленно ж, медленно их на реплике применять если большой поток

blkmrkt
Записывать не медленно ж, медленно их на реплике п...

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

blkmrkt- Автор вопроса
Valery
Так оно и на реплике тоже в один поток... Может кт...

Я про логическую репликацию :) Тут и правда все в один процесс, но не все так просто как с бинарной репликацией: нужно квери планы заново строить, искать какие индексы обновлять, проверять unique constraints и тому подобное.

blkmrkt
Я про логическую репликацию :) Тут и правда все в ...

Я прочитал. Эти расходы что в одной что в двух репликах будут, и не факт что в двух репликах их будет меньше

blkmrkt- Автор вопроса
Valery
Я прочитал. Эти расходы что в одной что в двух реп...

С одной подпиской уже одно ядро запинено на 100% и расти некуда. С двумя подписками будут 2 ядра работать на 50%, но минус в том что таблицы нужно осторожно распределять между публикациями чтоб не дай б-г одна трансакция записала сразу в 2 публикации на мастере.

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

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

Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Hi guys, I'm looking for a good LLM course. Is there any course to learn LLMs in advanced? I'm aiming to use them in my apps, so a perfect course in my openion, is not only a ...
Taha
14
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
а чем лучше всего сделать глобальный лок, если много нодов, до сотни? ну то есть мне надо, чтобы некоторые операции с объектом не происходили одновременно. перемещение между н...
Д. П.
10
Всем привет. Подскажите, пожалуйста, как вы реализовываете следующий функционал. Допустим есть форма, в которой имеется выпадающий список со значениями. Значения хранятся в БД...
Евгений
7
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
Карта сайта