• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PostgreSQL 主备数据宕机恢复测试方案

    主节点宕机数据,备库数据恢复

    背 景

    在从节点停止服务,然后往主库不断写入数据,然后把主机宕机掉,启动从库,把主库宕机期间的增量wal日志复制到从库的archive目录下, 执行恢复脚本,则会把主机宕机后的增量数据追加到数据库。

    环境

    服务器 角色
    10.10.56.16 master
    10.10.56.18 slave

    - 配置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+Pgpool实现HA主备切换的操作
    • PostgreSQL 数据同步到ES 搭建操作
    • postgresql 如何查看pg_wal目录下xlog文件总大小
    • postgresql之使用lsn 获取 wal文件名的实例
    • 修改postgresql存储目录的操作方式
    • postgresql运维之远程迁移操作
    • postgresql 12版本搭建及主备部署操作
    上一篇:PostgreSQL使用MySQL外表的步骤详解(mysql_fdw)
    下一篇:SpringBoot连接使用PostgreSql数据库的方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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