暂无图片
暂无图片
1
暂无图片
暂无图片
暂无图片

HALO DATABASE高级架构-分组复制

冷狼 2024-08-19
73

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;


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

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论