在docker上摆设postgresSQL主从

王柳  论坛元老 | 2024-7-25 19:03:11 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 1911|帖子 1911|积分 5733

一、主从规划

由于就一台服务器,以是两台服务器的ip是一样的,我采用了不同的端口
IP地点名称备注x.x.x.x:1922mymaster主库x.x.x.x:1921mystl备库 必要提前配置好Docker容器
二、创建PostgresSQL的Docker镜像

  1. docker pull postgres:14
复制代码

查看镜像是否创建成功
  1. docker images
复制代码

三、主库摆设

1、建立pgsql主库的data地点

以root用户创建目次
  1. mkdir -p /usr/local/data
  2. master
复制代码
2、启动docker镜像

  1. # 一些参数的说明
  2. # docker run
  3. #     --name <docker_nname>    # 启动后容器的名称
  4. #     --restart=always                                         # docker的自动重启
  5. #     -v <data_address>:/var/lib/postgresql/data                # 数据卷挂载,前面的地址即为第一步创建的地址
  6. #     -e POSTGRES_PASSWORD=<password>        # pgsql的密码
  7. #     -p <port>:5432                                # 端口映射,
  8. #     -d  <image_id>                                # 镜像名或ID
  9. docker run --name mymaster -e POSTGRES_PASSWORD=这里是你的密码 -p 1922:5432 -v /usr/local/datamaster/postgres:/var/lib/postgresql/data -d postgres:14
复制代码

查看数据库是否创建成功
  1. docker ps
复制代码

记住名称,后边要用
3、docker内操作

  1. # 进入docker容器,这里这个mymaster就是上边记住的名称
  2. docker exec -it mymaster bash
  3. # 进入pgsql
  4. su postgres
  5. psql
复制代码

  1. # 创建复制用户
  2. CREATE ROLE replica login replication encrypted password '这里是你的密码!';
  3. # 查看是否创建成功
  4. \du
  5. # 退出
  6. exit
  7. exit
复制代码

4、修改配置文件

退出容器
进入该数据库创建容器时初配置的数据文件位置

/usr/local/datamaster/postgres/arc 必须存在,假如不存在,则也必要mkdir一次
  1. mkdir -p /usr/local/data
  2. master
  3. /postgres/arcchmod 777 /usr/local/datamaster/postgres/arc
复制代码
  1. # 修改<data_address>/postgresql.conf
  2. vim postgresql.conf
  3. archive_mode = on
  4. archive_command = 'test ! -f /usr/local/datamaster/postgres/arc/%f'
  5. wal_level = replica
  6. max_wal_senders = 32
  7. wal_keep_size = 16
  8. wal_sender_timeout = 60s
  9. # 以下两个检查一下,我的docker启动后,自动就配置好了,如果被注释了,也需要修改
  10. listen_addresses = '*'
  11. max_connections = 100
复制代码




  1. # 修改<data_address>/pg_hba.conf
  2. vim pg_hba.conf
  3. # 在最后新增一行
  4. host    replication     replica         172.0.0.0/8            md5
复制代码

由于加载了数据卷,第三四步对配置文件的修改,和对不用Linux启动的pgsql本质上没有太大的差别,乃至可以以为是相同的操作
  1. # 因为配置了自动重启<--restart=always>,所以无需手动重启docker,不过也可以手动重启
  2. # 重启docker
  3. docker restart mymaster
复制代码

四、摆设从数据库

1、建立psql备库的data地点

以root用户创建目次
  1. mkdir -p /usr/local/data
复制代码
2、启动docker镜像

  1. # 一些参数的说明
  2. # docker run
  3. #     --name <docker_nname>    # 启动后容器的名称
  4. #     --restart=always                                         # docker的自动重启
  5. #     -v <data_address>:/var/lib/postgresql/data                # 数据卷挂载,前面的地址即为第一步创建的地址
  6. #     -e POSTGRES_PASSWORD=<password>        # pgsql的密码
  7. #     -p <port>:5432                                # 端口映射,
  8. #     -d  <image_id>                                # 镜像名或ID
  9. docker run --name mystl -e POSTGRES_PASSWORD=这里是你的密码 -p 1921:5432 -v /usr/local/data/postgres:/var/lib/postgresql/data -d postgres:14
复制代码
3、备库从主库同步

进入容器
  1. docker exec -it mystl bash
复制代码
  1. # 删除原数据
  2. # 注:因为启动了docker自启动,删除文件目录,会导致容器退出,甚至报错无法再次进入
  3. # 所以以下两步【删除数据,迁移数据】最好快速连续执行
  4. # 也可以直接执行迁移数据的操作,确认报错是【文件已存在,无法迁移】后,再【删除】后【迁移】
  5. rm -rf /var/lib/postgresql/data/*
  6. # 迁移主库数据
  7. pg_basebackup -R -D /var/lib/postgresql/data -P -h 你的主机IP -p 1922 -U replica
  8. # 提示输入密码
  9. 这一步要快
  10. # 出现以下代表数据迁移
  11. 26288/26288 kB (100%), 1/1 tablespace
  12. # 退出docker
  13. exit
  14. exit
  15. # 重启docker容器
  16. docker restart mystl
复制代码

tip:假如删除之后备库崩了,可以退出备库,docker restart mystl重启docker然后在进入备库
4、检查是否同步

  1. # 在从库的</url/local/data/>存在postgresql.auto.conf文件,自动出现以下内容代表数据创建成功
  2. cat postgresql.auto.conf
  3. primary_conninfo = 'user=replica password=123456 channel_binding=prefer host=172.16.23.77 port=10031 sslmode=prefer sslcompression=0 sslsni=1 ssl_min_protocol_version=TLSv1.2 gssencmode=prefer krbsrvname=postgres target_session_attrs=any'
复制代码

五、测试主从数据库

主库:

备库:


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

王柳

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表