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
相关推荐
凌云拓界8 小时前
文件管理:让AI安全操作你的电脑 ——CogitoAgent开发实战(三)
javascript·人工智能·架构·开源·node.js
杨浦老苏8 小时前
开源多用户图书追踪系统LibrisLog
docker·群晖·收藏管理
凌云拓界8 小时前
联网能力:让AI看见更广阔的世界 ——CogitoAgent开发实战(四)
javascript·人工智能·架构·node.js·创业创新
Cosolar8 小时前
保姆级 CrewAI 教程:从零构建多智能体协作系统
人工智能·python·架构
wb043072019 小时前
厨房实况直播——从阿明的“外卖骑手追踪系统“,看实时系统与事件驱动架构
架构
绿算技术9 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
赵渝强老师9 小时前
【赵渝强老师】Kubernetes(K8s)中的金丝雀升级
linux·docker·云原生·容器·kubernetes
heimeiyingwang10 小时前
【架构实战】分布式事务Saga模式:长事务的优雅解决方案
分布式·架构
我叫张小白。11 小时前
CentOS 7 安装 Docker并配置镜像加速(完整指南)
linux·docker·centos