Docker + PostgreSQL 主从环境搭建

环境说明

  • Docker
  • Ubuntu/CentOS
  • PostgreSQL v10.1

1. 运行PostgreSQL

1.1 主库

    docker run --name pgsmaster -p 5500:5432 -e POSTGRES_PASSWORD=pgsmaster -v $(pwd)/pgsmaster:/var/lib/postgresql/data -d postgres

1.2 从库

    docker run --name pgsslave -p 5501:5432 -e POSTGRES_PASSWORD=pgsslave -v $(pwd)/pgsslave:/var/lib/postgresql/data -d postgres

  进入以上主、从库对应的实际挂载目录执行下面的操作

2. 配置master(主库)

2.1 编辑pg_hba.conf,在最下面添加如下:

    // replication_username: 复制账号; slave_ip: 从库所在的服务器ip
    host    replication     <replication_username>      <slave_ip>/32          md5

2.2 编辑postgresql.conf(亲测,非必须),更改如下:

    synchronous_standby_names = '*'

2.3 进入容器,登录PostgreSQL,创建复制账号并验证:

# 1.进入容器
        docker exec -it pgsmaster bash
# 2.连接PostgreSQL
        psql -U postgres
# 3.创建用户
        set synchronous_commit =off;
        // replication_username: 对应上面设置的复制账号; replication_username_password: 认证密码
        create role <replication_username> login replication encrypted password '<replication_username_password>';  
# 4.验证用户
        \du

3. 配置Slave(从库)

3.1 编辑postgresql.conf(亲测,非必须),更改如下:

    hot_standby_feedback = on

3.2 新建recovery.conf,添加如下内容:

    standby_mode = 'on'
    // replication_username: 复制账号(同主库); master_ip: 主库所在的服务器ip; master_port: 主库端口; replication_username_password: 认证密码
    primary_conninfo = 'host=<master_ip> port=<master_port> user=<replication_username> password=<replication_username_password>'

4. 同步主从库数据及测试

4.1 停止PostgreSQL

    docker stop pgsmaster 
    docker stop pgsslave

4.2 同步主从库数据(必须)

  • 方法1:rsync
    // 1.1 已ssh认证,请将$(pwd)更改为实际的路径
    rsync -cva --inplace --exclude=*pg_xlog* $(pwd)/pgsmaster/ <slave_ip>:$(pwd)/pgsslave/
    // 1.2 无ssh认证,请将$(pwd)更改为实际的路径
    rsync -cva --inplace --exclude=*pg_xlog* $(pwd)/pgsmaster/ ssh root@<slave_ip>:$(pwd)/pgsslave/
  • 方法2:pg_basebackup(自行谷歌)

4.3 先后启动主库、从库服务

    docker start pgsmaster 
    docker start pgsslave

4.4 连接测试

    // 进入主库容器
    docker exec -it pgsmaster bash
    // 查看复制状态
    psql -U postgres -x -c "select * from pg_stat_replication;"

查看复制状态

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏SpringBoot 核心技术

SpringCloud组件:Eureka服务注册是采用主机名还是IP地址?

我们一直在使用Eureka进行注册服务,然而你有可能很少关心服务在注册到Eureka Server时是采用的主机名的方式?还是IP地址的方式?

29910
来自专栏圣杰的专栏

Azure Web连接到Azure MySql Db

12030
来自专栏企鹅号快讯

5个强大的Java分布式缓存框架

往期精选 在开发中大型Java软件项目时,很多Java架构师都会遇到数据库读写瓶颈,如果你在系统架构时并没有将缓存策略考虑进去,或者并没有选择更优的缓存策略,那...

53460
来自专栏Java架构沉思录

每天学点Linux命令之umask

在进入今天的主题之前,我们先来回顾一下Linux文件权限的相关知识点。Linux里的文件权限可分为3组,分别是文件拥有者、同个群组的其他用户、不同群组的其他用户...

7010
来自专栏猿人谷

mac下使用github

      提起github相信大家都不会陌生,在这里就不再赘述了。作为开源代码库以及版本控制系统,使用好了确实会非常受益,再说的势利点,你找工作时给面试官说你...

21350
来自专栏xingoo, 一个梦想做发明家的程序员

Log4j官方文档翻译(一、基本介绍)

简介 log4j是使用java语言编写的可靠的、快速的、灵活的日志框架,它是基于Apache的license。 log4j支持c,c++,c#,perl,...

21350
来自专栏算法修养

Flask 学习篇一: 搭建Python虚拟环境,安装flask,并设计RESTful API。

前些日子,老师给我看了这本书,于是便开始了Flask的学习 ? GitHub上的大神,于是我也在GitHub上建了一个Flask的项目。 有兴趣可以看看: ht...

64480
来自专栏编程

根据已有网络安装fabric-explorer

1.环境准备: lnodejs 6.9.x(不支持v7.x) lmysql 5.7或更高版本 lHyperledger Fabric 1.0 2.跑通网络: 假...

747100
来自专栏散尽浮华

Linux操作系统启动流程梳理

接触linux系统运维已经好几年了,常常被问到linux系统启动流程问题,刚好今天有空来梳理下这个过程: 一般来说,所有的操作系统的启动流程基本就是: ? 总的...

30180
来自专栏difcareer的技术笔记

一种更优的方式获取私有API

在编译私有的Android SDK中讲述了如何通过编译一个完整的SDK来获取一些稀有的API,但是这个方法有几点不足:

11730

扫码关注云+社区

领取腾讯云代金券