postgresql 查看用户密码_阐述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 /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  login replication encrypted password ''; # 4.验证用户 du

3. 配置Slave(从库)

3.1 编辑postgresql.conf,更改如下:

 hot_standby = on hot_standby_feedback = on

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

 standby_mode = 'on' // replication_username: 复制账号(同主库); master_ip: 主库所在的服务器ip; master_port: 主库端口; replication_username_password: 认证密码 primary_conninfo = 'host= port= user= 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/ :$(pwd)/pgsslave/ // 1.2 无ssh认证,请将$(pwd)更改为实际的路径 rsync -cva --inplace --exclude=*pg_xlog* $(pwd)/pgsmaster/ ssh root@:$(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;"
5220537c7e22d3483b2de1eea03503e5.png

最后针对于java程序员价值上万架构视频资料免费分享给大家(包括Dubbo、Redis、Netty、zookeeper、Spring cloud、分布式、高并发等架构技术资料),希望能帮助到且找到一个好的工作,也节省大家在网上搜索资料的时间来学习,也可以关注我一下以后会有更多干货分享。要资料请私信回复:获取免费资料!!