из реплик (а еще лучше всю реплику) как read-only, чтобы туда нельзя было писать?
Нужно это для того, чтобы безопасно вытаскивать сервер из репликации, чтобы он не успел нахватать партов, которые бы не успел раздать до того, как его потушат
есть какие-нибудь идеи? Ну, кроме как делать юзеров read-only
так просто не пишите туда, не совсем понятно что вам мешает
ну, это как бы не совсем просто, я б даже сказал что совсем непросто надо городить какой-то внешний атрибут, его доводить до клиентов итд было б гораздо проще если бы просто все попытки отбивались ошибкой и клиенты фолбечились на другую реплику
я надеюсь внешние клиенты не пишут напрямую в КХ?
гм, конечно пишут батчингу они обучены, если вы на это намекаете 🙂
я намекаю что у вас нет никакого контроля) как минимум прокси какой не мешало бы повесить, чтобы управлять трафиком
а как вы выводите КХ из кластера? или имеется в виду потушат временно?
нет, тушится постоянно (надо сервер освободить, например). выводится просто - все реплицируемые таблицы дропаются, и кх тушится. Но как показала практика, иногда такое приводит к потерянным партам
ну смотрите, вы дропаете таблицы, а кто туда пишет в этот момент? Он же ошибку получает table does not exists
да, те кто туда писал, получат ошибку и поретрают в другую реплику
а кто туда пишет-то? Distributed таблицы?
в основном напрямую разные клиенты
так уберите эту ноду из dns у этих клиентов, или как вы там список куда писать храните
ну это понятное решение, но там не все так просто, разные языки и технологии и все жутко асинхронно хотелось бы как-то управлять этим с сервера, но чет похоже нет хорошего решения даже если делать юзера ридонли, это не влияет на текущие коннекты, по моим тестам. И я даже не нашел как эти коннекты найти и дропнуть со стороны кх
пихнуть readonly=2 в default профиль?
не поможет для открытых коннектов
https://kb.altinity.com/altinity-kb-setup-and-maintenance/altinity-kb-shutting-down-a-node/ А вообще такая процедура есть
тоже не поможет они напишут после того как запущена SYSTEM SYNC REPLICA db.table;
Если про живые сессии? Тогда фаервол поднять на этой ноде. (или мб load balancer умеет рвать коннекшены 2 пункт)
Обсуждают сегодня