1.HALO DATABASE分组复制简介
在一个典型的同城灾备集群中,可以将同中心备节点的同步级别设置为remote_apply,同城灾备中心备节点的同步级别设置为on,从而既可以实现同城rpo=0(即故障恢复后不丢失数据,跟故障前的数据状态是一致的),又最大程度保证主库性能。
2.分组复制功能实现前提
启用分组复制必须先配置同步复制参数synchronous_standby_name和synchronous_commit,再按照需要配置synchronous_standby_nameX和synchronous_commitX(X为1-4)。
synchronous_commitX设置的同步级别必须低于或者等于synchronous_commit设置的同步级别。
3.分组复制主要参数设置
分组复制除了主分组,最多还可以设置分个四组,涉及到的主要参数
配置分组复制的服务器:
synchronous_standby_name1
synchronous_standby_name2
synchronous_standby_name3
synchronous_standby_name4配置每个分组的不同同步级别:
synchronous_commit1
synchronous_commit2
synchronous_commit3
synchronous_commit44.分组复制安装配置:
准备4台服务器
主库
node1:10.16.16.155
从库
node2: 10.16.16.156
node3:10.16.16.157
node4:10.16.16.1624.1.创建流复制用户
CREATE USER replica PASSWORD '123456' REPLICATION;4.2.修改postgersql.conf
vi /data/halo/postgresql.conf
listen_addresses = 'localhost' 修改为listen_addresses = '*' 分组复制的配置:
synchronous_standby_names='1(node2,node4)'
synchronous_standby_names1='1(node3)'synchronous_commit=remote_apply synchronous_commit1=on
4.3 配置pg_hba.conf
vi /data/halo/pg_hba.conf
host replication replica 10.16.16.0/24 md5 做完1,2,3步需要重启数据库
pg_ctl restart4.4 主备库配置
vi /etc/hosts
10.16.16.155 node1 (主库ip)
10.16.16.156 node2 备库ip
10.16.16.157 node3 备库ip --同城灾备
10.16.16.162 node4 备库ip4.5从库配置
备库执行:
10.16.16.156:
pg_basebackup -F p -X stream -v -P -h 10.16.16.155 -U replica -D $PGDATA -R -C --slot node2
启动数据库:
pg_ctl start
10.16.16.157:
pg_basebackup -F p -X stream -v -P -h 10.16.16.155 -U replica -D $PGDATA -R -C --slot node3
启动数据库:
pg_ctl start
10.16.16.162:
pg_basebackup -F p -X stream -v -P -h 10.16.16.155 -U replica -D $PGDATA -R -C --slot node4
启动数据库:
pg_ctl start将所有备库里的/data/halo/postgresql.auto.conf文件里的内容注释掉

4.6 修改备库里的/data/halo/postgresql.conf文件
vi /data/halo/postgresql.conf
10.16.16.156:
primary_conninfo = 'user=replica password=123456 channel_binding=prefer host=10.16.16.155 port=1921 sslmode=prefer sslcompression=0 sslsni=1 ssl_min_protocol_version=TLSv1.2 gssencmode=disable krbsrvname=halo target_session_attrs=any application_name=node2'
--重载
pg_ctl reload
查询:
show primary_conninfo;
10.16.16.157:
primary_conninfo = 'user=replica password=123456 channel_binding=prefer host=10.16.16.155 port=1921 sslmode=prefer sslcompression=0 sslsni=1 ssl_min_protocol_version=TLSv1.2 gssencmode=disable krbsrvname=halo target_session_attrs=any application_name=node3'
--重载
pg_ctl reload
查询:
show primary_conninfo;
10.16.16.162:
primary_conninfo = 'user=replica password=123456 channel_binding=prefer host=10.16.16.155 port=1921 sslmode=prefer sslcompression=0 sslsni=1 ssl_min_protocol_version=TLSv1.2 gssencmode=disable krbsrvname=halo target_session_attrs=any application_name=node4'
--重载
pg_ctl reload
查询:
show primary_conninfo;4.7 主库上查询复制流
select * from pg_stat_replication;
show synchronous_standby_names;
show synchronous_standby_names1;
show synchronous_commit;
show synchronous_commit1;
至此,分组复制架构配置完毕。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




