PostgreSQL配置主从备份(docker)

一、服务器规划

序号 IP 备注
1 192.168.1.110 主数据库
2 192.168.1.120 从数据库

二、服务器部署

2.1、主服务器部署(192.168.1.110)

1)、于/opt/postgresql目录下,编辑docker-compose.yml

复制代码
version: "3"
services:
  postgres-master:
    image: pgrouting/pgrouting:12-3.1-3.1.3
    container_name: postgres12-slave
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: 7Y6G#pg2789#Ws
    ports:
      - 5432:5432
    volumes:
      - ./data:/var/lib/postgresql/data
      - /etc/localtime:/etc/localtime:ro
        #将外边时间直接挂载到容器内部,权限只读
        #    restart: always

2)、启动服务

复制代码
cd /opt/postgresql
docker-compose up -d

3)、连接主数据库,创建主从复制(流复制)用户

执行创建SQL语句

复制代码
CREATE ROLE replica login replication encrypted password '123456';

4)、修改./data/pg_hba.conf文件

复制代码
1)允许远程登录
   host all all  192.168.1.120/24 md5
2)允许从数据库链接主数据库去拖wal日志数据
   host replication replica 192.168.1.120/32 md5
3)配置用户的访问权限
  在ipv4下加入host all all 192.168.1.120/24 md5
修改postgres.conf文件
1)允许所有地址监听
       listen_addresses='*'
2)开启归档模式
      archive_mode = on 
3)归档配置
%p 是被归档的redo文件的路径, 
%f 是被归档的redo文档的文件名  
%% 是百分号
archive_command ='cp -i %p /4T/%f </dev/null'
4)主从设置为热血模式,流复制必选
   wal_level=hot_standby
5)流复制允许连接进程
   max_wal_senders=5
6)pg_wal保留策略
       wal_keep_segments=64
7) 中断连接和表示到数据库的连接数
      wal_sender_timeout = 60s
      max_connections=1000

5)、重启主数据库服务

复制代码
cd /opt/postgresql
docker-compose down
docker-compose up -d

2.2、从服务器部署(192.168.1.120)

1)、于/opt/postgresql目录下,编辑docker-compose.yml

bash 复制代码
version: "3"
services:
  postgres-slave:
    image: pgrouting/pgrouting:12-3.1-3.1.3
    container_name: postgres12-slave
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: 7Y6G#pg2789#Ws
    ports:
      - 5432:5432
    volumes:
      - ./data:/var/lib/postgresql/data
      - /etc/localtime:/etc/localtime:ro
        #将外边时间直接挂载到容器内部,权限只读
        #    restart: always

2)、启动服务

bash 复制代码
cd /opt/postgresql
docker-compose up -d

3)、进入到从库postgres的容器内配置流复制

bash 复制代码
docker exec -it postgres12-slave /bin/bash
#切换到postgres用户
su - postgres
#使用pg_basebackup命令备份主数据库中的数据
pg_basebackup -h 192.168.1.110 -p 5432 -U replica --password -X stream -Fp --progress -D /var/lib/postgresql/data/pgdata -R;

4)、修改postgres.conf配置

bash 复制代码
# 在备份的同时允许查询
hot_standby=on
# 流复制最大延迟 (可选)
max_standby_streaming_delay=30s
# 从向主报告状态的最大间隔时间 (可选)
wal_receiver_status_interval=10s
# 查询冲突时向主反馈 #默认参数,非主从配置相关参数,表示到数据库的连接数 (可选)
hot_standby_feedback=on
# 一般从库做主要的读服务时,设置值需要高于主
max_connections=1000

5)、停止从数据库,配置docker-compose.yml文件

bash 复制代码
cd /opt/postgresql
docker-compose down

于/opt/postgresql目录下,编辑docker-compose.yml

bash 复制代码
version: "3"
services:
  postgres-slave:
    image: pgrouting/pgrouting:12-3.1-3.1.3
    container_name: postgres12-slave
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: 7Y6G#pg2789#Ws
    ports:
      - 5432:5432
    volumes:
      #- ./data:/var/lib/postgresql/data
      - ./data/pgdata:/var/lib/postgresql/data
      - /etc/localtime:/etc/localtime:ro  
        #将外边时间直接挂载到容器内部,权限只读
        #    restart: always

三、验证主从是否成功

1、连接数据库执行如下SQL命令

bash 复制代码
select client_addr,sync_state from pg_stat_replication;

2、连接数据执行如下SQL命令

bash 复制代码
select pg_is_in_recovery();
相关推荐
终端行者6 分钟前
Jenkins Pipeline 企业级用法 参数化构建+Ansible发布---上
docker·ansible·jenkins·cicd
ccice0125 分钟前
硬核实战:调用Gemini多模态管道,直击办公中的图表解析、发票识别与自动化脚本生成(国内镜像免费方案)
运维·自动化
爱喝水的鱼丶27 分钟前
SAP-ABAP:数据类型与数据对象(8篇) 第七篇:进阶优化篇——基于类型与对象特征的性能优化技巧
运维·数据库·学习·性能优化·sap·abap·开发交流
DFT计算杂谈42 分钟前
VASP新手入门: IVDW 色散修正参数
linux·运维·服务器·python·算法
qq_366032781 小时前
Claude API中转怎么选?简易api下的国内接入与兼容 OpenAI 接口实践
大数据·运维·人工智能
Donk_671 小时前
HAProxy实验搭建
运维·负载均衡
青梅橘子皮1 小时前
Linux---开发工具(2)(makefile、进度条、git、gdb)
linux·运维·服务器
亚空间仓鼠1 小时前
Docker容器化高可用架构部署方案(十三)
docker·容器·架构
剑神一笑1 小时前
Linux less 命令深度解析:从源码看分页器的设计智慧
linux·运维·less
李白你好2 小时前
Linux 本地提权工具支持Linux 内核和 Polkit 漏洞
linux·运维·服务器