博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Greenplum移除节点
阅读量:7152 次
发布时间:2019-06-29

本文共 2590 字,大约阅读时间需要 8 分钟。

基于某某原因,我们的Greenplum需要卸载一个节点(测试环境的Greenplum集群),由于该集群使用了很久,里面有许多开发所需要的数据,所以在卸掉一个节点后,还要保证数据不会丢失。

经过搜索,在以下站点找到了解决方案

1)
2)

当然,期间也遇到了点问题,在此也做个总结和记录。

1,备份数据【本次使用gp_dump备份】

gp_dump [-a | -s] [-c] [-d] [-D] [-n schema] [-o] [-O]     [-t table_name] [-T table_name] [-x] [-h hostname] [-p port]     [-U username] [-W] [-i] [-v] [--gp-c] [--gp-d=backup_directory]     [--gp-r=reportfile] [--gp-s=dbid [, ...]] database_namegp_dump -? | --help gp_dump --version

该指令最简洁的使用方式为

gp_dump database_name ;

即直接跟要备份的数据库名即可。

Greenplum移除节点

如上图显示有文件上使用的时间错以及备份文件在各个节点上的存储位置。

2,将要移除节点上的备份文件拷贝到master节点上。

3,从集群中移除节点

Greenplum移除节点

1)关闭数据库

gpstop -M fast

2)以管理模式启动数据库

gpstart -m

3)在master节点上登录管理数据库

PGOPTIONS="-c gp_session_role=utility" psql -d postgres

Greenplum移除节点

4)查看当前节点

select * from gp_segment_configuration;

Greenplum移除节点

5)设置操作权限

set allow_system_table_mods='dml';

Greenplum移除节点

6)删除节点(161)

delete from gp_segment_configuration where dbid=2;delete from pg_filespace_entry where fsedbid=2;

Greenplum移除节点

注意:这里很重要,我们需要将删除后不连续的索引通过update将其修改成连续的,不然启动的时候会报以下错误:

[gpadmin@ultra-hp-157 root]$ gpstart -a20190427:13:45:19:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Starting gpstart with args: -a20190427:13:45:19:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Gathering information and validating the environment...20190427:13:45:19:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Greenplum Binary Version: 'postgres (Greenplum Database) 5.0.0-alpha.8 build commit:548dc837c957d8c4834445b642cda1f0a5bf9b66'20190427:13:45:19:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Greenplum Catalog Version: '301705051'20190427:13:45:19:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Starting Master instance in admin mode20190427:13:45:20:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Obtaining Greenplum Master catalog information20190427:13:45:20:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Obtaining Segment details from master...20190427:13:45:21:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Setting new master era20190427:13:45:21:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Master Started...20190427:13:45:21:002659 gpstart:ultra-hp-157:gpadmin-[INFO]:-Shutting down master20190427:13:45:22:002659 gpstart:ultra-hp-157:gpadmin-[CRITICAL]:-gpstart failed. (Reason=''NoneType' object has no attribute 'valid'') exiting...

7)退出管理模式,正常启动数据库

gpstop –mgpstart

8)将删除节点的备份文件使用psql恢复到当前数据,例如:

psql ioss_dns -f /data/greenplumdatabak/dump_161/gp_dump_0_2_20190427074146

其中ioss_dns为数据库名;gp_dump_0_2_20190427074146为备份的数据文件。

到此,移除节点成功。

以上是通过并行备份的方式来备份数据,在各个节点上都会备份各个数据库的数据,也就是数据备份文件是分散在各个节点上的。 除此之外还可以通过非并行的方式来备份数据,原理就是将所有的数据都备份到master节点上,在数据量较小的情况下还是比较实用,具体操作不在赘述,上面提供的参考连接中有详细介绍。

转载于:https://blog.51cto.com/dengshuangfu/2395692

你可能感兴趣的文章
命令行解析器
查看>>
用ajaxFileUpLoad上传文件不能正确取得返回值的问题
查看>>
Aqua Data Studio 查询结果中文乱码
查看>>
js推断指定函数、变量是否存在的方法
查看>>
用python实现的线程池
查看>>
关于智能本质的思考
查看>>
Microsoft Capicom 2.1 On 64bit OS
查看>>
2016第21周三问题记录
查看>>
页面中多个script块之间的关系
查看>>
软件开发过程模型
查看>>
CloudFlare Support - Error 522: Connection timed out 错误522:连接超时
查看>>
Maven项目环境搭建实例.
查看>>
Atitit.信息论原理概论attilax总结
查看>>
Openfire 的安装和配置
查看>>
好,开始没做出来 guess-number-higher-or-lower-ii
查看>>
[LeetCode] Find Right Interval 找右区间
查看>>
android View 绘制完成监听
查看>>
igbinary vs serialize vs json_encode
查看>>
Snipaste强大离线/在线截屏软件的下载、安装和使用
查看>>
禅与摩托车维修的艺术
查看>>