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

HALO DATABASE高级架构-分组复制

贾桂权 2024-11-11
67

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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论