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
相关推荐
数据知道7 小时前
PostgreSQL 核心原理:如何利用多核 CPU 加速大数据量扫描(并行查询)
数据库·postgresql
金刚猿7 小时前
01_虚拟机中间件部署_root 用户安装 docker 容器,配置非root用户权限
docker·中间件·容器
yunteng5217 小时前
通用架构(同城双活)(单点接入)
架构·同城双活·单点接入
JH_Kong8 小时前
解决 WSL 中 Docker 权限问题:从踩坑到完整修复
docker·容器
忆~遂愿8 小时前
GE 引擎与算子版本控制:确保前向兼容性与图重写策略的稳定性
大数据·开发语言·docker
麦聪聊数据8 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
程序员侠客行9 小时前
Mybatis连接池实现及池化模式
java·后端·架构·mybatis
bobuddy10 小时前
射频收发机架构简介
架构·射频工程
桌面运维家10 小时前
vDisk考试环境IO性能怎么优化?VOI架构实战指南
架构
70asunflower12 小时前
Emulation,Simulation,Virtualization,Imitation 的区别?
linux·docker