zoukankan      html  css  js  c++  java
  • docker下postgis主从分离部署

    主服务的IP:192.168.153.133

    从服务的IP:192.168.153.134

    一、主服务器

    1、拉取镜像

    docker pull mdillon/postgis

    2、创建容器

    docker run --name pg-master --restart=always  -v /data/postgresql/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD=123456 -p 5432:5432 -d mdillon/postgis
    docker run --name pg-slave --restart=always  -v /data/postgresql/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD=123456 -p 5432:5432 -d mdillon/postgis

    3、在主服务器上给从服务器添加同步数据权

    1)创建同步数据用户

    docker exec -it pg-master bash
    su postgres
    psql
    CREATE ROLE replica login replication encrypted password 'replica';

    退出docker容器,回到宿主机

    2)允许从库同步数据

    vi /data/postgresql/data/pg_hba.conf
    在最下面添加
    host   replication      replica       192.168.153.134/32          trust

    4、修改主服务器(192.168.153.133)的postgresql.conf

    vi /data/postgresql/data/postgresql.conf

    listen_addresses = '*' # 监听所有IP archive_mode = on # 允许归档 archive_command = '/bin/date' # 用该命令来归档logfile segment,这里取消归档。 wal_level = replica #开启热备 max_wal_senders = 32 # 这个设置了可以最多有几个流复制连接,差不多有几个从,就设置几个 wal_keep_segments = 64 # 设置流复制保留的最多的xlog数目,一份是 16M,注意机器磁盘 16M*64 = 1G wal_sender_timeout = 60s # 设置流复制主机发送数据的超时时间 max_connections = 200 # 这个设置要注意下,从库的max_connections必须要大于主库的

    退出docker容器,回到宿主机

    5、重启主服务器的容器

    docker restart pg-master

    二、从服务器

    1、在从服务器上将主服务器的数据同步到从数据库

    docker exec -it pg-slave bash 
    su postgres
    rm -rf /var/lib/postgresql/data/*
    pg_basebackup -D $PGDATA -Fp -Xs -v -P -h 192.168.153.133 -U replica -W

    退出docker容器,回到宿主机

    2、添加恢复文件

    vi /data/postgresql/data/recovery.conf
    
    standby_mode = on
    primary_conninfo = 'host=192.168.153.133 port=5432 user=replica password=replica'
    recovery_target_timeline = 'latest'

    3、修改postgresql.conf

    vi /data/postgresql/data/postgresql.conf
    wal_level = replica
    max_connections = 1000
    hot_standby = on
    max_standby_streaming_delay = 30s
    wal_receiver_status_interval = 10s 
    hot_standby_feedback = on

    4、启动容器

    docker start pg-slave

    5、在主服务器上校验主从部署

    docker exec -it pg-master bash
    su postgres
    psql
    select client_addr,sync_state from pg_stat_replication;
    不为空创建成功
  • 相关阅读:
    SPOJ ADAFIELD Ada and Field(STL的使用:set,multiset,map的迭代器)题解
    hdu 6444 网络赛 Neko's loop(单调队列 + 裴蜀定理)题解
    hdu6446 网络赛 Tree and Permutation(树形dp求任意两点距离之和)题解
    HDU6447 网络赛 YJJ's Salesman(DP + 线段树)题解
    HDU 6438 网络赛 Buy and Resell(贪心 + 优先队列)题解
    BZOJ 3155 Preprefix sum
    BZOJ 2743 采花
    BZOJ 3339 Rmq Problem
    BZOJ 1660 乱发节
    BZOJ 3531 旅行
  • 原文地址:https://www.cnblogs.com/xiaofengfree/p/13402875.html
Copyright © 2011-2022 走看看