на более мощные, решили добавить новые ноды как реплики, дождаться синхронизации и отключить старые.
Нет ли какого-то мануала или статьи по этому процессу?
Интересует в первую очередь как переносить юзеров не меняя пароли? Можно ли скопировать хеши? И если можно то откуда?
А также нужно ли вручную выполнять ддл на новых нодах или есть способ этот процесс автоматизировать? Например, при помощи копирования метаданных?
можно /access папку скопировать там в текстовых файлах юзера, профайлы, роли. кстати это можно хранить в зукипере и тогда это будет расскатываться на все сервера кластера, без on cluster
О классно, спасибо большое! А где можно поискать инфу про это? Сегодня все доки излазил, про access вроде нашёл, а про то как это хранить в зукипере нигде не видел.
это в config.xml наверное описано <yandex> <user_directories replace="replace"> <users_xml> <path>/etc/clickhouse-server/users.xml</path> </users_xml> <replicated> <zookeeper_path>/clickhouse/access/</zookeeper_path> </replicated> </user_directories> </yandex> там проблема только что всех пользователей/роли/etc нужно создать заново, потому что оно заменит хранимое в файлах (файлы в /access перестанут использоваться) вот тут возможно подробнее https://kb.altinity.com/altinity-kb-integrations/altinity-cloud/altinity-cloud-access-management/
Спасибо! А как новые ноды удобнее всего добавлять не подскажете, пожалуйста? Вручную ddl исполнять или есть более простой вариант?
ох не знаю. у меня есть скрипт которому я даю адрес старой ноды и юзер/пароль он итерируется через все бд system.databases и создает if not exists, потом через все таблицы, и тоже if not exists, ну и берет create table из system.tables и с учетом порядка, типа сначала replicatedMT, потом replicatedreplacing, потом MV, потом вью, потом словари (расшарить скрипт я не могу, там вплетена внутренняя cmdb и вообще много про внутрее устройство компании)
Обсуждают сегодня