pg热备与主备切换_select pg_is_in_recovery();

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

host    all             all          0.0.0.0/0       md5
host replication      repuser         slave          md5
2.4 配置postgresql.conf

在master端配置如下:

listen\_addresses = '\*' 
port = 5432 
max\_wal\_senders = 1 
wal\_level = replica
archive\_mode = on 
archive\_command = 'cd ./'
hot\_standby = on
wal\_keep\_segments = 64
full\_page\_writes = on
wal\_log\_hints = on

配置完成后,重启master数据库

[postgres@bogon ~]$ pg_ctl restart -D $PGDATA
2.5 pg_basebackup 创建备库

在slave端的postgres账户下执行:

#切换到postgres账户
[root@bogon ~]# su - postgres
#从主库备份创建备库
[postgres@bogon ~]$ pg_basebackup -D $PGDATA -Fp -Xs -v -P -h master -p 5432 -U repuser
transaction log start point: 0/2000060 on timeline 1
pg_basebackup: starting background WAL receiver
22806/22806 kB (100%), 1/1 tablespace                                         
transaction log end point: 0/2000130
pg_basebackup: waiting for background process to finish streaming ...
pg_basebackup: base backup completed

修改slave中data目录下的pg_hba.conf最后一行修改如下:

host    all             all          0.0.0.0/0            md5
host replication       repuser       master               md5
2.6 配置recovery.conf

Master端配置如下:

[postgres@bogon ~]$ ls
bin  data  gdal  geos  include  lib  proj4  share
[postgres@bogon ~]$ cp share/recovery.conf.sample data/recovery.done
[postgres@bogon ~]$ vim data/recovery.done
#编辑内容如下
recovery_target_timeline = 'latest'
standby_mode = on
primary_conninfo = 'host=slave port=5432 user=repuser password=repuser'
trigger_file = '/home/postgres/data/trigger\_file'

Salve端配置如下:

[postgres@bogon ~]$ ls
bin  data  gdal  geos  include  lib  proj4  share
[postgres@bogon ~]$ cp share/recovery.conf.sample data/recovery.conf
[postgres@bogon ~]$ vim data/recovery.conf
#编辑内容如下
recovery_target_timeline = 'latest'
standby_mode = on
primary_conninfo = 'host=master port=5432 user=repuser password=repuser'
trigger_file = '/home/postgres/data/trigger\_file'
2.7 配置.pgpass

master上配置访问slave参数

[postgres@bogon ~]$ vim .pgpass
slave:5432:postgres:repuser:repuser

slave上配置访问master参数

[postgres@bogon ~]$ vim .pgpass
master:5432:postgres:repuser:repuser
2.8 流复制数据同步测试

分别启动master,slave数据库
在master上创建一个数据库和临时表

[postgres@bogon data]$ psql
psql (9.6.1)
Type "help" for help.
postgres=# \password  #创建数据库密码
#创建测试数据库
postgres=# create database test;
CREATE DATABASE
postgres=# \c test
You are now connected to database "test" as user "postgres".
test=# create table tt(id serial not null,name text);
CREATE TABLE
test=# insert into tt(name) values ('china');
INSERT 0 1

在slave上查询刚才创建的表和数据,判定是否有数据同步

[postgres@bogon data]$ psql
psql (9.6.1)
Type "help" for help.

postgres=# \c test
You are now connected to database "test" as user "postgres".
test=# select \* from tt;
 id | name  
----+-------
  1 | china
(1 row)

很明显,从库已经同步了主库的数据,到此可以说PG流复制热备已经创建结束了。以下对流复制做一些简单的应用。

三 主备切换

一般可以通过若干命令查询数据库的主备属性,主数据库是读写的,备数据库是只读的。当主数据库宕机了,可以通过建立触发文件,备数据库将被提升为主数据库,实现一些基本的HA应用。

3.1 查询主备
3.1.1 pg_controldata

主机

[postgres@localhost ~]$ pg_controldata
pg_control version number:            960
Catalog version number:               201608131
Database system identifier:           6362107256088627972
Database cluster state:               in production

备机

pg_control version number:            960
Catalog version number:               201608131
Database system identifier:           6362107256088627972
Database cluster state:               in archive recovery

主机的cluster state是in production,备机的cluster state是in archive recovery。

3.1.2 字典表pg_stat_replication

在主机字典表中是能查到记录,备机中是查询不到的。

postgres=# select pid,application\_name,client\_addr,client\_port,state,sync\_state from pg\_stat\_replication;
 pid | application\_name | client\_addr | client\_port | state | sync\_state 
-------+------------------+---------------+-------------+-----------+------------
 17131 | walreceiver | 192.168.0.105 | 55734 | streaming | async
(1 row)
3.1.3 进程信息识别

进程中显示wal sender的是主机,显示wal receiver的是备机
master:

主机进程.png

slave:

备机进程.png

3.1.4 通过pg函数

备机是t,主机是f。
主机

postgres=# select pg\_is\_in\_recovery();
 pg_is_in_recovery 
-------------------
 f
(1 row)

备机

postgres=# select pg\_is\_in\_recovery();
 pg_is_in_recovery 
-------------------
 t
(1 row)
3.2 备机切换成主机

主机宕机前:
宕机前备机进程.png

主机执行pg_ctl stop 命令。
宕机后:

主机宕机后.png

备机报错,说不能连接主机了。
之前曾配置过:

 trigger_file = '/home/postgres/datatrigger\_file'

备机切换到主机,在备机上执行

[postgres@localhost ]$  touch /home/postgres/data/trigger_file;

再去备机上查看进程:
备机进程.png

备机已经切换到主机了。
3.3 原来主机切换成备机

在当前主机(现在是slave了,主机切换了)执行插入语句

postgres=#  insert into tt(name) values('sdf');

如果master上data目录中的recovery.done没有变成recovery.conf,可以手动强制更改。

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

…(img-xGUqbQ7W-1715812790113)]
[外链图片转存中…(img-BECgTZzN-1715812790113)]
[外链图片转存中…(img-L1m7nm5u-1715812790113)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值