• 售前

  • 售后

热门帖子
入门百科

PostgreSQL 主备数据宕机恢复测试方案

[复制链接]
塞上云烟辣 显示全部楼层 发表于 2021-10-26 13:48:03 |阅读模式 打印 上一主题 下一主题
主节点宕机数据,备库数据恢复

背 景
在从节点停止服务,然后往主库不绝写入数据,然后把主机宕机掉,启动从库,把主库宕机期间的增量wal日记复制到从库的archive目次下, 实行恢复脚本,则会把主机宕机后的增量数据追加到数据库。
环境
      服务器      角色                  10.10.56.16      master              10.10.56.18      slave    - 配置16 master 的 pg_hba,conf 文件
  1. host all  all  10.10.56.0/0  md5
  2. host replication all  10.10.56.0/0  trust
  3. "pg_hba.conf" 96L, 4652C
复制代码
配置16 master的 postgresql.conf
  1. listen_addresses = '*'
  2. max_connections = 1000
  3. wal_level = logical
  4. archive_mode = on
  5. archive_command = '/bin/true'
  6. log_destination = 'csvlog'
  7. logging_collector = on
  8. log_filename = 'postgresql-%Y-%m-%d.log'
  9. log_rotation_size = 20MB
  10. log_statement = 'mod'
  11. log_replication_commands = on
  12. deadlock_timeout = 100ms
复制代码
配置18 slave,初始化数据库从master pg_basebackup
  1. /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 ,从归档目次恢复数据
  1. #standby_mode = 'on'
  2. #primary_conninfo = 'user=repl password=123456 host=10.10.56.16 port=5432 sslmode=disable sslcompression=1 target_session_attrs=any'
  3. restore_command = 'cp /pgdata/10/archive/%f %p'
复制代码
以上就实现了主从异步流复制
启动16查询 为 f 表示为 主库
  1. pocdb=# select pg_is_in_recovery();
  2. pg_is_in_recovery
  3. -------------------
  4. f
  5. (1 row)
  6. Time: 0.786 ms
  7. pocdb=#
复制代码
在16 创建用户 repl 、创建表、略
主库16正常时,p表数据为
  1. pocdb=# select max(id) from p;
  2. max
  3. ---------
  4. 3774121
  5. (1 row)
复制代码
从库18 p表数据
  1. pocdb=# select max(id) from p;
  2. max
  3. ---------
  4. 3774121
  5. (1 row)
复制代码
主库宕机前(16)
  1. pocdb=# select max(id) from p;
  2. max
  3. ---------
  4. 4005263
  5. (1 row)
复制代码
主库(16)宕机后,从库举行恢复后,数据已经追加:
  1. postgres@clw-db3:/pgdata/10/poc/data> /opt/pgsql-10/bin/psql pocdbpsql (10.3)Type "help" for help.pocdb=# select max(id) from p;
  2. max
  3. ---------
  4. 4005263
  5. (1 row)
复制代码
补充:postgresql在windows重装后怎样重新恢复的方法
配景

windows体系重装后我们的postgresql服务器就不会正常启动,因为在体系中注册的服务重装后已经没有了,但是你的postgresql不是安装在体系盘区上的,那么postgresql服务器的文件和数据就还是存在的,比如原来的安装目次是D:\PostgreSQL,那么我们怎么让服务器服务自动运行起来,如许我们的步伐才气毗连数据库了,而且数据还不会丢失。
处理方法

第一种方法:
最简朴的办法重装,把原来的文件全部删除,如果原来有数据备份,把备份数据恢复就可以了,那如果重装体系前没有备份数据呢?这种办法就找不回原来的数据了,对于开发者来说是很头疼的,那么我给大家先容第二种方法,前提是数据库的安装目次和数据库数据目次文件夹都是完好无损的,否则我也没办法了;
第二种方法:
重新注册服务,实在比重新安装还简朴了;实行下令就可以了,
第一步:进入到数据库的安装目次,cd D:\PostgreSQL\bin;
第二部:实行服务注册:
  1. 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权限,否则不能毗连;

以上为个人履历,希望能给大家一个参考,也希望大家多多支持草根技能分享。如有错误或未考虑完全的地方,望不吝见教。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作