docker版postgresql数据库主从配置

dockerpostgresql主从配置

参考:postgresql16配置主从

注意项 :当前操作主路径:~/dockerEnv【示例路径】

txt 复制代码
操作目录结构如下:
- dockerEnv
-- dbInit
--- a_create_user.sql
-- pg_data
--- ......
--- ......
  1. 创建sql文件,文件路径dockerEnv/dbInit/a_create_user.sql
sql 复制代码
-- 主从同步账号
CREATE ROLE replicator REPLICATION LOGIN PASSWORD 'abc';

-- 添加用户
create user swmg with password 'abc';

-- 创建数据库
create database sis_server;

-- 将数据库的管理权授予用户
grant all privileges on database sis_server to swmg;

1.0、主从数据库的容器yml文件

注意: 如果在同一个宿主机操作,注意多个yml文件的端口映射,不要冲突!

  • 挂载宿主机sql文件夹到容器的docker-entrypoint-initdb.d路径下,容器启动时,会按照文件夹内的sql文件命名顺序自动执行sql文件。
  1. 主数据库docker-compose.yml文件

    yml 复制代码
    version: '3'
    services:
      dbServer:
        image: "postgres:12.5"
        restart: always
        container_name: pg_server_master
        environment:
          POSTGRES_DB: sis_server
          POSTGRES_USER: postgres
          POSTGRES_PASSWORD: swissmic
          PGDATA: /var/lib/postgresql/data
          TZ: 'Asia/Shanghai'
        volumes:
          - ./data:/var/lib/postgresql/data:rw
          - ../dbInit:/docker-entrypoint-initdb.d/:rw
        ports:
          - "10000:5432"
        command: ["docker-entrypoint.sh", "postgres"]
  2. 从数据库docker-compose.yml文件

    从数据库,仅比主数据库多了一个中转文件夹backup_data的挂载,主要是为了方便从主数据库备份数据库文件后,迁移使用。

    yml 复制代码
    version: '3'
    services:
      dbServer:
        image: "postgres:12.5"
        restart: always
        container_name: pg_server_slave
        environment:
          POSTGRES_DB: sis_server
          POSTGRES_USER: postgres
          POSTGRES_PASSWORD: swissmic
          PGDATA: /var/lib/postgresql/data
          TZ: 'Asia/Shanghai'
        volumes:
          - ./data:/var/lib/postgresql/data:rw
          - ./data-transfer:/var/lib/postgresql/backup_data:rw
          - ../dbInit:/docker-entrypoint-initdb.d/:rw
        ports:
          - "10000:5432"
        command: ["docker-entrypoint.sh", "postgres"]

1.1、主数据库

  1. 修改pg_hba.conf文件,追加如下内容:

    shell 复制代码
    # 允许replicator账号进行连接
    host    replication     replicator      0.0.0.0/0       md5
  2. 修改postgresql.conf文件,追加如下内容:

    shell 复制代码
    hot_standby = on        # 打开热备
    wal_level = replica     # 设置 WAL 日志级别为 replica
    max_wal_senders = 3     # 允许的 WAL 发送者数量,根据需要进行调整
    archive_mode = on       # 启用归档模式。PostgreSQL 会将 WAL 日志归档到指定的归档目录中。
    
    # 归档模式,指定wal日志归档路径(手动创建archive路径)
    archive_command = 'cp "%p" /var/lib/postgresql/data/archive/%f'
  3. 手动创建archive归档路径,并重启容器

1.2、从数据库

  1. 进入容器的/var/lib/postgresql/backup_data路径下,执行以下命令,拉取主数据库信息。(子数据库启动时,yml多挂在了一个中转数据的文件夹)
    • 备份主数据库数据,会要求使用空文件夹,所以挂载了一个backup_data路径,备份数据后,方便在宿主机直接操作替换
    • 备份的主数据文件中,多了一个standby.signal文件,此文件保留不动,不用增加内容
    • 同时,postgresql.auto.conf内会自动生成主服务器的连接地址,此文件不需要改动
shell 复制代码
# 这个命令,会从主数据库拉取备份,从数据库使用拉取的数据,实现主从同步
pg_basebackup -h 192.168.2.59 -p 40001 -U replicator -D . -Fp -Xs -Pv -R --checkpoint=fast
  1. 执行完后,关闭从数据库容器。

  2. 在宿主机中,将data-transfer文件夹替换掉pg_data文件夹(删掉pg_data,将data-transfer改名为pg_data),然后重启子数据库容器(让子数据库使用主数据库拉取的数据库文件,重启子数据库,会自动进行主从同步)。

故障恢复

主数据库故障

当主数据库故障时,删除子数据库的standby.signal文件,重启子数据库容器,则从数据库将恢复成生产模式,系统再修改数据库连接,指向子数据库的ip端口即可。

相关推荐
Cachel wood几秒前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
Python之栈7 分钟前
【无标题】
数据库·python·mysql
风_流沙19 分钟前
java 对ElasticSearch数据库操作封装工具类(对你是否适用嘞)
java·数据库·elasticsearch
亽仒凣凣27 分钟前
Windows安装Redis图文教程
数据库·windows·redis
年薪丰厚34 分钟前
如何在K8S集群中查看和操作Pod内的文件?
docker·云原生·容器·kubernetes·k8s·container
亦世凡华、36 分钟前
MySQL--》如何在MySQL中打造高效优化索引
数据库·经验分享·mysql·索引·性能分析
YashanDB38 分钟前
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
数据库·yashandb·崖山数据库
ProtonBase1 小时前
如何从 0 到 1 ,打造全新一代分布式数据架构
java·网络·数据库·数据仓库·分布式·云原生·架构
摸鱼也很难6 小时前
Docker 镜像加速和配置的分享 && 云服务器搭建beef-xss
运维·docker·容器
云和数据.ChenGuang6 小时前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite