Docker 启动 PostgreSQL 主从架构:实现数据同步

1、准备环境

IP地址 主机名 角色
10.16.12.115 postgresql01 主库
10.16.12.116 postgresql02 从库

3、拉取postgresql镜像

bash 复制代码
docker pull registry.cn-hangzhou.aliyuncs.com/qiluo-images/postgres-with-gis:16.4

4、创建db网络

bash 复制代码
docker network create --driver bridge dbnet

5、创建数据目录

bash 复制代码
mkdir /data/postgresql/data -p
chmod -R 777 /data/postgresql/data

docker-compose.yml文件编写

主库文件:

bash 复制代码
sudo tee /data/postgresql/docker-compose.yml <<-'EOF'
version: '3.0'
services:
  postgresql:
    image: registry.cn-hangzhou.aliyuncs.com/qiluo-images/postgres-with-gis:16.4
    restart: always
    container_name: postgresql01
    environment:
      POSTGRES_PASSWORD: admin@123
    working_dir: /postgresql
    networks:
      - dbnet
    ports:
      - "5432:5432"
    volumes:
      - /data/postgresql/data:/var/lib/postgresql/data
 
networks:
  dbnet:
    external: true
EOF

从库文件:

bash 复制代码
sudo tee /data/postgresql/docker-compose.yml <<-'EOF'
version: '3.0'
services:
  postgresql:
    image: registry.cn-hangzhou.aliyuncs.com/qiluo-images/postgres-with-gis:16.4
    restart: always
    container_name: postgresql02
    environment:
      POSTGRES_PASSWORD: admin@123
    working_dir: /postgresql
    networks:
      - dbnet
    ports:
      - "5432:5432"
    volumes:
      - /data/postgresql/data:/var/lib/postgresql/data
 
networks:
  dbnet:
    external: true
EOF

启动postgresql服务

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

部署主库

bash 复制代码
docker exec -it postgresql01 /bin/bash
su - postgres
psql
CREATE ROLE replica login replication encrypted password 'replica@123';
bash 复制代码
修改postgresql.conf
vi /data/postgresql/data/postgresql.conf

```bash
listen_addresses = '*'
archive_mode = on
archive_command = '/bin/date'
max_connections = 1024
max_wal_senders = 32
wal_sender_timeout = 60s
wal_keep_size = 16
wal_level = replica

修改pg_hba.conf

vi /data/postgresql/data/pg_hba.conf

bash 复制代码
host    replication     replica        0.0.0.0/32        trust

部署从库

bash 复制代码
docker exec -it postgresql02 /bin/bash
在容器中运行相关命令:
rm -rf /var/lib/postgresql/data/*

如果退出了,则再次进入

bash 复制代码
docker exec -it postgresql02 /bin/bash
su - postgres
pg_basebackup -R -D /var/lib/postgresql/data -P -h 192.168.52.15 -p 5432 -U replica
bash 复制代码
docker restart postgresql02 
# 查看/data/postgresql/data下的 postgresql.auto.conf

、查看进程

主机查看主数据库

bash 复制代码
ps -ef|grep postgres

从机查看从数据库

bash 复制代码
docker ps |grep postgres

测试同步

在主机容器中

bash 复制代码
docker exec -it postgresql01 /bin/bash
su - postgres
psql
create database test12;
\list

在从机查看已经同步

bash 复制代码
docker exec -it postgresql02 /bin/bash
su - postgres
psql
\list

关闭selinux

bash 复制代码
sed -i 's#SELINUX=enforcing#SELINUX=disabled#g' /etc/selinux/config
setenforce 0
相关推荐
无忧智库3 分钟前
深度解码:烟草行业数字化转型顶层设计与全场景落地实践(PPT)
安全·架构
ak啊17 分钟前
多智能体协同模式:五种核心架构详解
架构
IT枫斗者24 分钟前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
l1t28 分钟前
DeepSeek总结的PostgreSQL检查点和写入风暴
jvm·postgresql·oracle
迷藏49429 分钟前
**发散创新:基于角色与属性的混合权限模型在微服务架构中的实战落地**在现代分布式系统中,
java·python·微服务·云原生·架构
WindrunnerMax38 分钟前
从零实现富文本编辑器#13-React非编辑节点的内容渲染
前端·架构·github
ssshooter41 分钟前
Tauri 应用苹果签名踩坑实录
前端·架构·全栈
FelixBitSoul1 小时前
Docker 镜像 SIZE、DISK USAGE、Layer、Prune、.dockerignore 全面解析:pull 到底下载多少?
docker
modelmd1 小时前
Docker 重命名数据卷
运维·docker·容器
前进的李工1 小时前
智能Agent实战指南:从入门到精通(工具)
开发语言·人工智能·架构·langchain·agent·tool·agentexecutor