前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker + PostgreSQL 主从环境搭建

Docker + PostgreSQL 主从环境搭建

作者头像
happyJared
发布2018-09-20 09:57:41
2.7K0
发布2018-09-20 09:57:41
举报
文章被收录于专栏:happyJaredhappyJared

环境说明

  • Docker
  • Ubuntu/CentOS
  • PostgreSQL v10.1

1. 运行PostgreSQL

1.1 主库
代码语言:javascript
复制
    docker run --name pgsmaster -p 5500:5432 -e POSTGRES_PASSWORD=pgsmaster -v $(pwd)/pgsmaster:/var/lib/postgresql/data -d postgres
1.2 从库
代码语言:javascript
复制
    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,在最下面添加如下:
代码语言:javascript
复制
    // replication_username: 复制账号; slave_ip: 从库所在的服务器ip
    host    replication     <replication_username>      <slave_ip>/32          md5
2.2 编辑postgresql.conf(亲测,非必须),更改如下:
代码语言:javascript
复制
    synchronous_standby_names = '*'
2.3 进入容器,登录PostgreSQL,创建复制账号并验证:
代码语言:javascript
复制
# 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(亲测,非必须),更改如下:
代码语言:javascript
复制
    hot_standby_feedback = on
3.2 新建recovery.conf,添加如下内容:
代码语言:javascript
复制
    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
代码语言:javascript
复制
    docker stop pgsmaster 
    docker stop pgsslave
4.2 同步主从库数据(必须)
  • 方法1:rsync
代码语言:javascript
复制
    // 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 先后启动主库、从库服务
代码语言:javascript
复制
    docker start pgsmaster 
    docker start pgsslave
4.4 连接测试
代码语言:javascript
复制
    // 进入主库容器
    docker exec -it pgsmaster bash
    // 查看复制状态
    psql -U postgres -x -c "select * from pg_stat_replication;"

查看复制状态

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.06.27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 环境说明
  • 1. 运行PostgreSQL
    • 1.1 主库
      • 1.2 从库
      • 2. 配置master(主库)
        • 2.1 编辑pg_hba.conf,在最下面添加如下:
          • 2.2 编辑postgresql.conf(亲测,非必须),更改如下:
            • 2.3 进入容器,登录PostgreSQL,创建复制账号并验证:
            • 3. 配置Slave(从库)
              • 3.1 编辑postgresql.conf(亲测,非必须),更改如下:
                • 3.2 新建recovery.conf,添加如下内容:
                • 4. 同步主从库数据及测试
                  • 4.1 停止PostgreSQL
                    • 4.2 同步主从库数据(必须)
                      • 4.3 先后启动主库、从库服务
                        • 4.4 连接测试
                        相关产品与服务
                        容器服务
                        腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                        领券
                        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档