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_commit4
4.分组复制安装配置:
准备4台服务器
主库
node1:10.16.16.155
从库
node2: 10.16.16.156
node3:10.16.16.157
node4:10.16.16.162
4.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 restart
4.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 备库ip
4.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;

至此,分组复制架构配置完毕。




