当前位置: 首页 > news >正文

PostgreSQL配置主从备份(docker)

一、服务器规划

序号

IP

备注

1192.168.1.110主数据库
2192.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.3container_name: postgres12-slaveenvironment:POSTGRES_USER: postgresPOSTGRES_PASSWORD: 7Y6G#pg2789#Wsports:- 5432:5432volumes:- ./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 = 60smax_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

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

2)、启动服务


cd /opt/postgresql
docker-compose up -d

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


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配置

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

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


cd /opt/postgresql
docker-compose down

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

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

三、验证主从是否成功

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


select client_addr,sync_state from pg_stat_replication;

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

select pg_is_in_recovery();

http://www.lryc.cn/news/161595.html

相关文章:

  • qt作业day4
  • js如何实现字符串反转?
  • Nmap 7.94 发布:新功能!
  • 【深入解析spring cloud gateway】08 Reactor 知识扫盲
  • 常用ADB指令
  • 【HTML5高级第二篇】WebWorker多线程、EventSource事件推送、History历史操作
  • CentOS云服务器部署配置
  • 深入解析Java中的数组复制:System.arraycopy、Arrays.copyOf和Arrays.copyOfRange
  • libc和glibc有什么区别
  • 基于SSM的在线云音乐系统
  • 构建高效的BFF(Backend for Frontend):优化前端与后端协作
  • 喜报 | 实力亮相2023服贸会,擎创科技斩获领军人物奖创新案例奖
  • 科技革新自动驾驶:拓世AI智能助理携手跟您一起点亮未来之旅
  • 【HCIE】01.IGP高级特性
  • 知识大杂烩(uniapp)
  • Jmeter压测监控体系搭建Docker+Influxdb+Grafana
  • TDesign 点击高亮显示=》点击切换class类名
  • 容器编排学习(二)镜像制作和私有仓库介绍
  • tcp记录
  • IDEA中使用Java连接MySQL数据库的配置和使用方法
  • android——服务JobService
  • 一文讲清楚redis的线程池jedis
  • 备战面试每日一题
  • 【嵌入式数据库之sqlite3】
  • Android 9.0 pms中关于启动app时获取app的ActivityInfo信息相关源码分析
  • 华为数通方向HCIP-DataCom H12-821题库(单选题:321-340)
  • 《TCP/IP网络编程》阅读笔记--基于TCP的服务器端/客户端
  • 【每日一题】43. 字符串相乘
  • 机器学习——K最近邻算法(KNN)
  • 同步FIFO的verilog实现(1)——计数法