如何进行Greenplum移除节点
这期内容当中小编将会给大家带来有关如何进行Greenplum移除节点,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
基于某某原因,我们的Greenplum需要卸载一个节点(测试环境的Greenplum集群),由于该集群使用了很久,里面有许多开发所需要的数据,所以在卸掉一个节点后,还要保证数据不会丢失。
经过搜索,在以下站点找到了解决方案
1)https://gp-docs-cn.github.io/docs/admin_guide/managing/restore-diff-system.html
2)https://yq.aliyun.com/articles/173472
当然,期间也遇到了点问题,在此也做个总结和记录。
1,备份数据【本次使用gp_dump备份】
gp_dump[-a|-s][-c][-d][-D][-nschema][-o][-O][-ttable_name][-Ttable_name][-x][-hhostname][-pport][-Uusername][-W][-i][-v][--gp-c][--gp-d=backup_directory][--gp-r=reportfile][--gp-s=dbid[,...]]database_namegp_dump-?|--helpgp_dump--version
该指令最简洁的使用方式为
gp_dumpdatabase_name;
即直接跟要备份的数据库名即可。
如上图显示有文件上使用的时间错以及备份文件在各个节点上的存储位置。
2,将要移除节点上的备份文件拷贝到master节点上。
3,从集群中移除节点
1)关闭数据库
gpstop-Mfast
2)以管理模式启动数据库
gpstart-m
3)在master节点上登录管理数据库
PGOPTIONS="-cgp_session_role=utility"psql-dpostgres
4)查看当前节点
select*fromgp_segment_configuration;
5)设置操作权限
setallow_system_table_mods='dml';
6)删除节点(161)
deletefromgp_segment_configurationwheredbid=2;deletefrompg_filespace_entrywherefsedbid=2;
注意:这里很重要,我们需要将删除后不连续的索引通过update将其修改成连续的,不然启动的时候会报以下错误:
[gpadmin@ultra-hp-157root]$gpstart-a20190427:13:45:19:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-Startinggpstartwithargs:-a20190427:13:45:19:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-Gatheringinformationandvalidatingtheenvironment...20190427:13:45:19:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-GreenplumBinaryVersion:'postgres(GreenplumDatabase)5.0.0-alpha.8buildcommit:548dc837c957d8c4834445b642cda1f0a5bf9b66'20190427:13:45:19:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-GreenplumCatalogVersion:'301705051'20190427:13:45:19:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-StartingMasterinstanceinadminmode20190427:13:45:20:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-ObtainingGreenplumMastercataloginformation20190427:13:45:20:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-ObtainingSegmentdetailsfrommaster...20190427:13:45:21:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-Settingnewmasterera20190427:13:45:21:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-MasterStarted...20190427:13:45:21:002659gpstart:ultra-hp-157:gpadmin-[INFO]:-Shuttingdownmaster20190427:13:45:22:002659gpstart:ultra-hp-157:gpadmin-[CRITICAL]:-gpstartfailed.(Reason=''NoneType'objecthasnoattribute'valid'')exiting...
7)退出管理模式,正常启动数据库
gpstop–mgpstart
8)将删除节点的备份文件使用psql恢复到当前数据,例如:
psqlioss_dns-f/data/greenplumdatabak/dump_161/gp_dump_0_2_20190427074146
其中ioss_dns为数据库名;gp_dump_0_2_20190427074146为备份的数据文件。
到此,移除节点成功。
以上是通过并行备份的方式来备份数据,在各个节点上都会备份各个数据库的数据,也就是数据备份文件是分散在各个节点上的。 除此之外还可以通过非并行的方式来备份数据,原理就是将所有的数据都备份到master节点上,在数据量较小的情况下还是比较实用。
上述就是小编为大家分享的如何进行Greenplum移除节点了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。