Docker + PostgreSQL 主从环境搭建

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
简介: 环境说明DockerUbuntu/CentOSPostgreSQL v10.11. 运行PostgreSQL1.1 主库 docker run --name pgsmaster -p 5500:5432 -e POSTGRES_P...

环境说明

  • 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;"
img_c5bbf700782ace9755caf0ffe3deb149.png
查看复制状态
相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
5月前
|
机器学习/深度学习 算法 计算机视觉
3D目标检测框架 MMDetection3D环境搭建 docker篇
本文介绍如何搭建3D目标检测框架,使用docker快速搭建MMDetection3D的开发环境,实现视觉3D目标检测、点云3D目标检测、多模态3D目标检测等等。
122 0
|
6月前
|
存储 分布式计算 Hadoop
基于docker的Hadoop环境搭建与应用实践(脚本部署)
本文介绍了Hadoop环境的搭建与应用实践。对Hadoop的概念和原理进行了简要说明,包括HDFS分布式文件系统和MapReduce计算模型等,主要通过脚本的方式进行快捷部署,在部署完成后对HDFS和mapreduce进行了测试,确保其功能正常。
|
1月前
|
关系型数据库 分布式数据库 PolarDB
PolarDB常见问题之安装gms时出现docker如何解决
PolarDB是阿里云推出的下一代关系型数据库,具有高性能、高可用性和弹性伸缩能力,适用于大规模数据处理场景。本汇总囊括了PolarDB使用中用户可能遭遇的一系列常见问题及解答,旨在为数据库管理员和开发者提供全面的问题指导,确保数据库平稳运行和优化使用体验。
|
2月前
|
关系型数据库 数据库 PostgreSQL
Docker安装postgreSql
Docker安装postgreSql步骤
|
2月前
|
Java Linux 流计算
【极数系列】Flink环境搭建&Docker版本(04)
【极数系列】Flink环境搭建&Docker版本(04)
|
3月前
|
Ubuntu 开发工具 git
rk3588 镜像构建环境搭建基于docker
构建镜像环境搭建过程
121 1
|
3月前
|
存储 Ubuntu Docker
Docker环境搭建
Docker环境搭建
37 0
|
3月前
|
中间件 关系型数据库 MySQL
史上最详细Docker安装Mycat中间件 | 实现主从的读写分离
史上最详细Docker安装Mycat中间件 | 实现主从的读写分离
95 2
|
4月前
|
关系型数据库 MySQL 数据库
分库分表之基于Shardingjdbc+docker+mysql主从架构实现读写分离(一)
分库分表之基于Shardingjdbc+docker+mysql主从架构实现读写分离(一)
|
4月前
|
关系型数据库 MySQL Java
分库分表之基于Shardingjdbc+docker+mysql主从架构实现读写分离(二)
分库分表之基于Shardingjdbc+docker+mysql主从架构实现读写分离(二)