温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么对PostgreSQL数据库主备数据宕机恢进行测试

发布时间:2021-01-08 16:35:11 来源:亿速云 阅读:139 作者:Leah 栏目:开发技术

这期内容当中小编将会给大家带来有关怎么对PostgreSQL数据库主备数据宕机恢进行测试,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

环境

服务器角色
10.10.56.16master
10.10.56.18slave

- 配置16 master 的 pg_hba,conf 文件

host all  all  10.10.56.0/0  md5
host replication all  10.10.56.0/0  trust
"pg_hba.conf" 96L, 4652C

配置16 master的 postgresql.conf

listen_addresses = '*'
max_connections = 1000 
wal_level = logical 
archive_mode = on 
archive_command = '/bin/true' 
log_destination = 'csvlog'
logging_collector = on 
log_filename = 'postgresql-%Y-%m-%d.log' 
log_rotation_size = 20MB 
log_statement = 'mod'
log_replication_commands = on
deadlock_timeout = 100ms

配置18 slave,初始化数据库从master pg_basebackup

 /opt/pgsql-10/bin/pg_basebackup -h 10.10.56.16 -U repl -W -Fp -Pv -Xs -R -D /pgdata/10/poc/data/

配置18的 recovery.conf ,从归档目录恢复数据

#standby_mode = 'on'
#primary_conninfo = 'user=repl password=123456 host=10.10.56.16 port=5432 sslmode=disable sslcompression=1 target_session_attrs=any'
restore_command = 'cp /pgdata/10/archive/%f %p'

以上就实现了主从异步流复制

启动16查询 为 f 表示为 主库

pocdb=# select pg_is_in_recovery();
 pg_is_in_recovery
-------------------
 f
(1 row)
Time: 0.786 ms
pocdb=#

在16 创建用户 repl 、创建表、略

主库16正常时,p表数据为

pocdb=# select max(id) from p;
 max
---------
 3774121
(1 row)

从库18 p表数据

pocdb=# select max(id) from p;
 max
---------
 3774121
(1 row)

主库宕机前(16)

pocdb=# select max(id) from p;
 max
---------
 4005263
(1 row)

主库(16)宕机后,从库进行恢复后,数据已经追加:

postgres@clw-db3:/pgdata/10/poc/data> /opt/pgsql-10/bin/psql pocdb
psql (10.3)
Type "help" for help.
pocdb=# select max(id) from p;
 max
---------
 4005263
(1 row)

补充:postgresql在windows重装后如何重新恢复的方法

背景

windows系统重装后我们的postgresql服务器就不会正常启动,因为在系统中注册的服务重装后已经没有了,但是你的postgresql不是安装在系统盘区上的,那么postgresql服务器的文件和数据就还是存在的,比如原来的安装目录是D:\PostgreSQL,那么我们怎么让服务器服务自动运行起来,这样我们的程序才能连接数据库了,而且数据还不会丢失。

处理方法

第一种方法:

最简单的办法重装,把原来的文件全部删除,如果原来有数据备份,把备份数据恢复就可以了,那如果重装系统前没有备份数据呢?这种办法就找不回原来的数据了,对于开发者来说是很头疼的,那么我给大家介绍第二种方法,前提是数据库的安装目录和数据库数据目录文件夹都是完好无损的,否则我也没办法了;

第二种方法:

重新注册服务,其实比重新安装还简单了;执行命令就可以了,

第一步:进入到数据库的安装目录,cd D:\PostgreSQL\bin;

第二部:执行服务注册:

pg_ctl register -N pg921 -D D:\PostgreSQL\data -S auto -w -t 10 -l D:/PostgreSQL/pg921.log -o "-p 5432",

-N pg921 代表注册服务的名称 ,-D代表数据库文件目录 ,-S代表服务启动方式auto自动,demand手动,-o "-p 5432"指启动服务端口;(可以通过pg_ctl --help命令查看使用方法)

第三步:启动服务,net start pg921;

通过上面的的方法就成功的注册了服务器,以后每次开机都可以使用数据库了;

但是postgresql自带的一个管理工具pgAdmin3还是不能正常使用,需要我们配置,配置方法见下图:

注意:服务项不需要填写,主机填写localhost,如果填写真实的ip,必须在数据库配置文件中配置ip权限,否则不能连接;

怎么对PostgreSQL数据库主备数据宕机恢进行测试

上述就是小编为大家分享的怎么对PostgreSQL数据库主备数据宕机恢进行测试了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI