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

Добрый день А есть какой-нибудь способ пометить реплицируемую таблицу на одной

из реплик (а еще лучше всю реплику) как read-only, чтобы туда нельзя было писать?
Нужно это для того, чтобы безопасно вытаскивать сервер из репликации, чтобы он не успел нахватать партов, которые бы не успел раздать до того, как его потушат

20 ответов

17 просмотров
Danila-Migalin Автор вопроса

есть какие-нибудь идеи? Ну, кроме как делать юзеров read-only

Danila Migalin
есть какие-нибудь идеи? Ну, кроме как делать юзеро...

так просто не пишите туда, не совсем понятно что вам мешает

Danila-Migalin Автор вопроса
Konstantin Ilchenko
так просто не пишите туда, не совсем понятно что в...

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

Danila Migalin
ну, это как бы не совсем просто, я б даже сказал ч...

я надеюсь внешние клиенты не пишут напрямую в КХ?

Danila-Migalin Автор вопроса
Konstantin Ilchenko
я надеюсь внешние клиенты не пишут напрямую в КХ?

гм, конечно пишут батчингу они обучены, если вы на это намекаете 🙂

Danila Migalin
гм, конечно пишут батчингу они обучены, если вы на...

я намекаю что у вас нет никакого контроля) как минимум прокси какой не мешало бы повесить, чтобы управлять трафиком

а как вы выводите КХ из кластера? или имеется в виду потушат временно?

Danila-Migalin Автор вопроса
Denny [Altinity]
а как вы выводите КХ из кластера? или имеется в ви...

нет, тушится постоянно (надо сервер освободить, например). выводится просто - все реплицируемые таблицы дропаются, и кх тушится. Но как показала практика, иногда такое приводит к потерянным партам

Danila Migalin
нет, тушится постоянно (надо сервер освободить, на...

ну смотрите, вы дропаете таблицы, а кто туда пишет в этот момент? Он же ошибку получает table does not exists

Danila-Migalin Автор вопроса
Denny [Altinity]
ну смотрите, вы дропаете таблицы, а кто туда пишет...

да, те кто туда писал, получат ошибку и поретрают в другую реплику

Danila-Migalin Автор вопроса
Denny [Altinity]
а кто туда пишет-то? Distributed таблицы?

в основном напрямую разные клиенты

Danila Migalin
в основном напрямую разные клиенты

так уберите эту ноду из dns у этих клиентов, или как вы там список куда писать храните

Danila-Migalin Автор вопроса
Denny [Altinity]
так уберите эту ноду из dns у этих клиентов, или к...

ну это понятное решение, но там не все так просто, разные языки и технологии и все жутко асинхронно хотелось бы как-то управлять этим с сервера, но чет похоже нет хорошего решения даже если делать юзера ридонли, это не влияет на текущие коннекты, по моим тестам. И я даже не нашел как эти коннекты найти и дропнуть со стороны кх

пихнуть readonly=2 в default профиль?

Dmitry [Altinity] Titov
пихнуть readonly=2 в default профиль?

не поможет для открытых коннектов

https://kb.altinity.com/altinity-kb-setup-and-maintenance/altinity-kb-shutting-down-a-node/ А вообще такая процедура есть

Dmitry [Altinity] Titov
https://kb.altinity.com/altinity-kb-setup-and-main...

тоже не поможет они напишут после того как запущена SYSTEM SYNC REPLICA db.table;

Denny [Altinity]
тоже не поможет они напишут после того как запуще...

Если про живые сессии? Тогда фаервол поднять на этой ноде. (или мб load balancer умеет рвать коннекшены 2 пункт)

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

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

Всем привет! Имеется функция: 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
Карта сайта