#CN节点扩缩容
YashanDB支持通过yasboot工具对存算一体分布式集群部署中的CN节点进行扩/缩容,执行具体操作前请仔细阅读相关注意事项。
Note:
如果扩缩容过程中现有节点出现故障、扩缩容失败等异常,请参考扩缩容异常处理进行处理。
# 新增CN节点
如需新增服务器并增加CN节点,请先参照安装前准备检查并确保新服务器系统的各项环境已满足要求。
以安装用户登录数据库的现有节点所在服务器。
结合实际场景,执行相应操作。
场景1:新增服务器并增加CN节点
- ) 执行yasboot config node gen命令,生成yashandb_add.toml和hosts_add.toml配置文件。
$ yasboot config node gen -c yashandb -u yashan -p password --ip ip1,ip2 --port 22 \ --install-path /data/yashan/yasdb_home --data-path /data/yashan/yasdb_data \ --log-path /data/yashan/log -g 2 --node 2- ) 执行如下命令,远程连接新服务器并为其安装YashanDB。
$ yasboot host add -c yashandb -t hosts_add.tomlNote:
按需在新服务器上完成以下配置:
- 若扩容前数据库已开启资源管理功能,在新服务器上执行yasboot host cgroup命令创建cgroup目录。
$ yasboot host cgroup create -c yashandb --sudo-username root --sudo-password ****** --host-id host004- 若扩容前其他服务器均已配置开机自启动,新服务器上也必须配置开机自启动。
场景2:在现有服务器上增加CN节点
执行yasboot config node gen命令,生成yashandb_add.toml配置文件。
$ yasboot config node gen -c yashandb --host-ids host0001,host0002 -g 2 --node 2
在上述生成配置文件的服务器上执行如下命令,增加CN节点。
$ yasboot node add -c yashandb -t yashandb_add.toml +-------------------------------------------------------------------------------------------------+ | type | uuid | name | hostid | index | status | return_code | progress | cost | +-------------------------------------------------------------------------------------------------+ | task | faac17066f99af00 | NodeAdd | - | yashandb | SUCCESS | 0 | 100 | 3 | +------+------------------+---------+--------+----------+---------+-------------+----------+------+ task completed, status: SUCCESS任务显示成功并不表示扩容任务已全部成功,可能仍有部分后台任务在完成数据的同步等操作。可以通过
task list命令查看扩容相关的任务是否都成功。$ yasboot task list -c yashandb --search type=NodeAdd(可选)备份数据库。
建议对数据库进行备份,确保扩容后有可用于恢复的基线备份集。
若采用新增服务器的方式进行扩容,扩容完成后需要把hosts_add.toml中的[[host]]内容复制粘贴到hosts.toml的末尾,以免升级时仍用旧的hosts信息。
# 删除CN节点
以安装用户登录数据库安装服务器。
执行如下命令,查看待删除的目标节点ID。
$ yasboot cluster status -c yashandb -d # nodeid中冒号前的部分即为节点ID,例如1-1:1对应的节点ID为1-1执行如下命令,删除CN节点。
# 可以增加--with-host参数,成功删除节点后继续删除当前集群中所有无数据库节点、无yasom进程的空服务器的信息 $ yasboot node remove -c yashandb --node-ids 2-4 --purge(可选)备份数据库。
建议对数据库进行备份,确保缩容后有可用于恢复的基线备份集。
若缩容时指定了--with-host参数(即移除了空服务器),缩容完成后需要更新hosts.toml文件的[[host]]内容,删除对应服务器相关信息,以免升级时仍用旧的hosts信息。

