[简介]

本文主要是介绍PostgreSQL数据库的热备技术,PostgreSQL数据库提供了类似Oracle的standby数据库的功能。PostgreSQL日志传送的方法有两种,一种是基于文件(base-file)的传送方式,一种是流复制(streamingreplication)的方式。基于文件(base-file)的传送方式,这种方式是PostgreSQL9.0之前就提供的方法。也就是服务器写完一个WAL日志文件后,才把WAL日志文件拷贝到standby数据库上去应用。流复制的方式是PostgreSQL提供的一种服务器间的数据复制方式。这是PostgreSQL9.0才提供的新方法。这个方法就是事务提交后,主服务器则在WAL记录产生时即将它们以流式传送给后备服务器而不必等到WAL文件被填充。就是把生成的日志异步的传送到standby数据库上应用,这比基本文件的日志传送方法有更低的数据延迟。

[环境准备]

1. 服务器两台:

服务器

IP

主数据库服务器

192.168.88.191

备数据库服务器

192.168.88.192

操作系统版本:CentOS-7-x86_64

软件:PostgreSQL10.10

安装目录是:/db/pgsql/

数据目录是:/db/pgsql_data/

注意:实施之前两台机器上都安装好了postgresql数据库

2. 确保操作系统防火墙已关闭

systemctl stopfirewalld

systemctl disablefirewalld

[搭建PostgreSQL 主备环境]

1)在主节点上的操作

切换用户,并执行启动服务命令:

su – postgres

pg_ctl start -D $PGDATA 启动服务。


创建用于流复制的用户。执行命令:

psql -h 127.0.0.1 -p 5432 -U postgres

进入PostgreSQL数据库,并执行如下语句创建用户:

create user repuser with login replication password '123456';

修改pg_hba.conf文件,添加如下内容,允许两台计算机上的复制用户和超级用户登录:

host    replication    repuser        192.168.88.191/32         md5

host    replication    repuser        192.168.88.192/32         md5

host      all          postgres          192.168.88.191/32             trust

host      all          postgres          192.168.88.192/32             trust

在主节点的postgresql.conf 中设置这些参数:

max_wal_senders = 10

wal_level = replica

wal_log_hints = on

wal_keep_segments = 10

wal_receiver_status_interval = 5s

hot_standby_feedback = on

参数含义:

max_wal_senders表示来自后备服务器或流式基础备份客户端的并发连接的最大数量;

wal_level表示日志级别,对于流复制,它的值应设置为replica;

wal_log_hints =on表示,在PostgreSQL服务器一个检查点之后页面被第一次修改期间,把该磁盘页面的整个内容都写入WAL,即使对所谓的提示位做非关键修改也会这样做;

wal_keep_segments指定在后备服务器需要为流复制获取日志段文件的情况下,pg_wal(PostgreSQL9.6 以下版本的是pg_xlog)目录下所能保留的过去日志文件段的最小数目;

log_connections表示是否在日志中记录客户端对服务器的连接;

wal_receiver_status_interval指定在后备机上的 WAL接收者进程向主服务器或上游后备机发送有关复制进度的信息的最小周期;

hot_standby_feedback指定一个热后备机是否将会向主服务器或上游后备机发送有关于后备机上当前正被执行的查询的反馈,这里设置为on。

关于详细内容,可以参考postgresql官方文档。

重启主节点:

pg_ctl restart -D $PGDATA

重启之后,为主服务器和后备服务器创建复制槽(该步非必做项):

select * frompg_create_physical_replication_slot('postgresql_node191');

select * frompg_create_physical_replication_slot('postgresql_node192');

创建后查询复制槽

select * from pg_replication_slots;

复制槽(replicationslot)的作用是:

1.在流复制中,当一个备节点断开连接时,备节点通过hot_standby_feedback提供反馈数据数据会丢失。当备节点重新连接时,它可能因为被主节点发送清理记录而引发查询冲突。复制槽即使在备节点断开时仍然会记录下备节点的xmin(复制槽要需要数据库保留的最旧事务ID)值,从而确保不会有清理冲突。

2.当一个备节点断开连接时,备节点需要的WAL文件信息也丢失了。如果没有复制槽,当备节点重连时,可能已经丢弃了所需要的WAL文件,因此需要完全重建备节点。而复制槽确保这个节点保留所有下游节点需要的WAL文件。

要配置slave使用这个槽,在后备机的recovery.conf中应该配置primary_slot_name,如下:

$ vi $PGDATA/recovery.conf

primary_slot_name = ' postgresql_node191'

standby_mode = 'on'

recovery_target_timeline = 'latest'

primary_conninfo = 'user=replicator password=1qaz2wsxhost=192.168.88.191 port=5432 application_name= postgresql_node192'

trigger_file = '/tmp/postgresql.trigger.5432'

---删除复制槽

slave在使用primary_slot_name 参数时是无法删除replication slots

postgres=# SELECT * FROM pg_drop_replication_slot('postgresql_node191');

postgres=# SELECT * FROM pg_drop_replication_slot('postgresql_node192');

2)在备节点上的操作

确保服务是停止的:

su - postgres

切换用户,并执行:

pg_ctl stop -D $PGDATA

关闭服务。

首先删除备节点中的数据目录$PGDATA 中的文件:

cd $PGDATA

rm –rf *

然后执行:

pg_basebackup -Xs -d "hostaddr=192.168.88.191 port=5432user=repuser password=123456" -D $PGDATA -v -Fp

这里,-Xs表示复制方式是流式的(stream),这种方式不会复制在此次备份开始前,已经归档完成的WAL文件;-d后面是一个连接字符串,其中“hostaddr=192.168.88.191”表示主服务器的ip地址是192.168.88.191,“port=5432”表示数据库的端口是5432,“user=repuser”表示用于流复制的用户是repuser,“password=123456”表示密码是123456;“-D$PGDATA”表示将备份内容输入到本地的$PGDATA 目录;“-v”表示打印详细信息,–Fp表示复制结果输出位普通(plain)文件。

如果遇到以下报错:

pg_basebackup: could not connect to server: could not connect toserver: No route to host

Is the server running on host "192.168.88.191" andaccepting

TCP/IP connections on port 5432?

pg_basebackup: removing contents of data directory "/db/pgsql_data"

用root清除下防火墙:

sudo iptables -F

基础备份完成后,修改备节点的postgresql.conf 文件设置:

hot_standby = on

将/db/pgsql/share/ 中的recovery.conf.sample 拷贝到$PGDATA 下,重命名为recovery.conf:

cp /db/pgsql/share/recovery.conf.sample $PGDATA/recovery.conf

并设置如下参数:

recovery_target_timeline = 'latest'

standby_mode = on

primary_conninfo = 'host=192.168.88.191 port=5432 user=repuserpassword=repuser123'

primary_slot_name = 'postgresql_node122'

trigger_file = 'tgfile'

上述参数含义如下:

recovery_target_timeline表示恢复到数据库时间线的上的什么时间点,这里设置为latest,即最新;

standby_mode表示是否将PostgreSQL服务器作为一个后备服务器启动,这里设置为on,即后备模式;

primary_conninfo指定后备服务器用来连接主服务器的连接字符串,其中“host=192.168.88.191”表示主服务器的ip地址是192.168.88.191,“port=5432”表示数据库的端口是5432,“user=repuser”表示用于流复制的用户是repuser,“password=123456”表示密码是123456;

primary_slot_name指定通过流复制连接到主服务器时使用一个现有的复制槽来控制上游节点上的资源移除。这里我们指定之前创建的postgresql_node122。如果没有在主服务器上创建复制槽,则不配置此参数;

trigger_file指定一个触发器文件,该文件的存在会结束后备机中的恢复,使它成为主机。

启动备节点服务:

pg_ctl start -D $PGDATA

pg_ctl stop -D $PGDATA

问题解决:

[postgres@postgresql2 pgsql_data]$ pg_ctl start -D $PGDATA

waiting for server to start....2020-06-15 18:22:49.203 EDT [2883]FATAL:  data directory "/db/pgsql_data" has group or worldaccess

2020-06-15 18:22:49.203 EDT [2883] DETAIL:  Permissions should beu=rwx (0700).

stopped waiting

pg_ctl: could not start server

Examine the log output.

Chmod 700 /db/pgsql_data

[主备环境检测]

在主节点上创建一个表,并插入数据:

postgres=# create table demo1  (id int, name varchar(20));

CREATE TABLE

postgres=# insert into demo1 (id, name)  values (1,'zhangsan');

INSERT 0 1

在备节点上检测:

postgres=# select * from demo1;

id | name

----+------

1 | zhangsan

主节点数据同步到了备机。

同时,在备节点上写数据会失败:

postgres=# insert into demo1 (id, name)  values (2,'wangwu');

ERROR:  cannot execute INSERT in a read-only transaction

[主备环境切换]

启动备节点,使之成为新的主节点:

pg_ctl promote -D $PGDATA

结果是:

waiting for server to promote........ done

server promoted

查看新主节点的状态:

postgres=#  pg_controldata | grep cluster

Database cluster state:              in production

插入数据后无报错:

postgres=#  insert into demo1 (id, name)  values (2,'wangwu');

INSERT 0 1

停止旧的主节点:

pg_ctl stop -m fast -D $PGDATA

结果:

waiting for server to shut down.... done

server stopped

在停止的旧主节点上执行恢复数据的操作:

pg_rewind --target-pgdata $PGDATA--source-server='host=192.168.88.192 port=5432 user=postgresdbname=postgres' -P

结果如下:

connected to server

servers diverged at WAL location 0/2B000230 on timeline 4

rewinding from last common checkpoint at 0/2A000098 on timeline 4

reading source file list

reading target file list

reading WAL in target

need to copy 57 MB (total source directory size is 143 MB)

58749/58749 kB (100%) copied

creating backup label and updating control file

syncing target data directory

Done!

表示从新主节点上成功获取WAL日志。

重新配置新备节点的recovery.conf:

recovery_target_timeline = 'latest'

standby_mode = on

primary_conninfo = 'hostaddr=192.168.88.192 port=5432 user=repuserpassword=repuser123'

primary_slot_name = 'postgresql_node121'

 在新备节点上执行下面的命令,重新启动该节点:

pg_ctl start -D $PGDATA

在新备节点上验证:insertinto提示为read-only

postgres=# insert into demo1 (id, name)  values (3,'lisi');

ERROR:  cannot execute INSERT in a read-only transaction

环境复制_PostgreSQL热备之流复制环境搭建以及常见问题处理相关推荐

  1. pitr 原理_PostgreSQL热备原理研究及流复制运用

    付莎 摘要:高可用性(HA-High Availability)是所有商用数据库系统必须具备的一项基本功能.该文阐述了PostgreSQL数据库的高可用性的实现原理及方法,并对PostgreSQL数据 ...

  2. java缓冲流 复制文件_java使用缓冲流复制文件的方法

    本文实例为大家分享了java使用缓冲流复制文件的具体代码,供大家参考,具体内容如下 [1] 程序设计 /*------------------------------- 1.缓冲流是一种处理流,用来加 ...

  3. mysql双机热备 读写分离_轻松搭建MySQL主从复制、读写分离(双机热备)

    主从复制: 当mysql数据库的数据量太大的时候,查询数据就很吃力了,无论怎么优化都会产生瓶颈,这时我们需要增加服务器设备来实现分布式数据库,实现多机热备份,要想实现多机的热备,首先要了解主从数据库服 ...

  4. mysql双机热备 读写分离_轻松搭建MySQL主从复制、读写分离双机热备)

    注意:如果此步骤始终为空设置(0.00秒),则表示先前的my.cnf配置不正确,请返回并重试检查配置步骤. (从)数据库中的配置 1.修改从属库的数据库配置文件 [root @ localhost]# ...

  5. Oracle的高级复制、流复制、备库的区别

    Oracle备份功能包括: 高级复制(Advanced Replication) 流复制(Streams Replication) 备库(Dataguard) 一 .dataguard: datagu ...

  6. PostgreSQL13主从同步异步流复制

    PostgreSQL13主从同步异步流复制 介绍 PostgreSQL早在9.0版本开始支持物理复制,也可称为流复制( Streaming Replication,通过流复制技术,可以从实例级复制出一 ...

  7. pgpool 主从流复制模式下的安装使用

    pgpool 主从流复制模式下的安装使用 pgpool-II 是一个位于 PostgreSQL 服务器和 PostgreSQL 数据库客户端之间的中间件,它提供以下功能:  连接池 pgpool-I ...

  8. 如何重启数据库服务(包含单实例/流复制/集群)

    目录 环境 文档用途 详细信息 环境 系统平台:N/A 版本:4.3.4.5,4.3.4.6,4.3.4.7,4.3.4.8,4.3.4.9,4.5 文档用途 本文档概述了单实例数据库.流复制环境和集 ...

  9. java oracle 流复制_Oracle流复制技术

    Oracle流复制是结合日志挖掘.队列等技术,实现多数据库.异构.远程等环境下数据同步的一种实现方式.主要被用于灵活的复制和容灾解决方案. Oracle流复制相比较其他数据库同步方式,如Datagua ...

最新文章

  1. 路由与交换大作业pkt_干货 | 交换机“练功大法”——略有小成(一)
  2. 设置更改root密码 ,连接mysql,mysql常用命令
  3. 这是一个有趣的问题,Java 8 Lambda 表达式被编译成了什么?
  4. Keras 实现 LSTM
  5. 施密特触发器(Schmitt Trigger)?
  6. stl vector 函数_vector :: back()函数以及C ++ STL中的示例
  7. 朝鲜不小心泄漏了它的.kp域名DNS数据
  8. 第二章 获取变量的相关统计指标
  9. 最简单的视音频播放示例6:OpenGL播放YUV420P(通过Texture,使用Shader)
  10. mysql存儲過程返回值_java如何获得mysql存储过程的返回值
  11. PHP网络版CRM客户管理系统
  12. 动态规划实战3-leetcode 55.Jump Game
  13. php 简繁体转换类库,简体中文转换为繁体中文的PHP函数
  14. python音乐实例详解_python下载无损音乐示例源码(qq音乐)
  15. vr软件测试,如何进行VR可用性测试?
  16. 微信图片信息存放搜狗输入法云端服务器怎么取消,搜狗输入法弹窗怎么去掉?搜狗输入法关闭弹窗的方法...
  17. 苹果 CEO 为什么选中了何同学?
  18. 阿里云域名https证书(ssl证书)配置
  19. jQuery - fadeIn淡入效果
  20. 【python】pycharm 中导入本地下载好的库

热门文章

  1. 5.与HTTP协作的Web服务器
  2. 爱创课堂每日一题第四十天- 说说你对语义化的理解?
  3. 阿里云Redis (安装包安装篇)
  4. Tiled 瓦片地图
  5. Java NIO示例:多人网络聊天室
  6. 杭电 hdu 2040
  7. ASP.NET页面刷新办法
  8. .NET UIAutomation实现Word文档加密暴力破解
  9. Oracle 把游标说透
  10. 简述C# XML解析方法的特点及应用