docker部署postgresSQL主从的方法步骤

 更新时间:2024年08月09日 11:15:35   作者:不会编程的喵星人  
本文主要介绍了docker部署postgresSQL主从的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、主从规划

因为就一台服务器,所以两台服务器的ip是一样的,我采用了不同的端口

IP地址名称备注
x.x.x.x:1922mymaster主库
x.x.x.x:1921mystl备库

需要提前配置好Docker容器

二、创建PostgresSQL的Docker镜像

docker pull postgres:14

在这里插入图片描述

查看镜像是否创建成功

docker images

在这里插入图片描述

三、主库部署

1、建立pgsql主库的data地址

以root用户创建目录

mkdir -p /usr/local/datamaster

2、启动docker镜像

# 一些参数的说明
# docker run 
#     --name <docker_nname>    # 启动后容器的名称 
#     --restart=always 					# docker的自动重启
#     -v <data_address>:/var/lib/postgresql/data		# 数据卷挂载,前面的地址即为第一步创建的地址
#     -e POSTGRES_PASSWORD=<password>	# pgsql的密码
#     -p <port>:5432				# 端口映射,
#     -d  <image_id>				# 镜像名或ID

docker run --name mymaster -e POSTGRES_PASSWORD=这里是你的密码 -p 1922:5432 -v /usr/local/datamaster/postgres:/var/lib/postgresql/data -d postgres:14

在这里插入图片描述

查看数据库是否创建成功

docker ps

在这里插入图片描述

记住名称,后边要用

3、docker内操作

# 进入docker容器,这里这个mymaster就是上边记住的名称
docker exec -it mymaster bash
# 进入pgsql
su postgres
psql

在这里插入图片描述

# 创建复制用户
CREATE ROLE replica login replication encrypted password '这里是你的密码!';
# 查看是否创建成功
\du
# 退出
exit
exit

在这里插入图片描述

4、修改配置文件

退出容器

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

在这里插入图片描述

/usr/local/datamaster/postgres/arc 必须存在,如果不存在,则也需要mkdir一次

mkdir -p /usr/local/datamaster/postgres/arc
chmod 777 /usr/local/datamaster/postgres/arc
# 修改<data_address>/postgresql.conf
vim postgresql.conf

archive_mode = on
archive_command = 'test ! -f /usr/local/datamaster/postgres/arc/%f'
wal_level = replica
max_wal_senders = 32
wal_keep_size = 16
wal_sender_timeout = 60s
# 以下两个检查一下,我的docker启动后,自动就配置好了,如果被注释了,也需要修改
listen_addresses = '*'
max_connections = 100

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

# 修改<data_address>/pg_hba.conf
vim pg_hba.conf
# 在最后新增一行
host    replication     replica         172.0.0.0/8            md5

在这里插入图片描述

因为加载了数据卷,第三四步对配置文件的修改,和对不用Linux启动的pgsql本质上没有太大的差别,甚至可以认为是相同的操作

# 因为配置了自动重启<--restart=always>,所以无需手动重启docker,不过也可以手动重启
# 重启docker
docker restart mymaster

在这里插入图片描述

四、部署从数据库

1、建立psql备库的data地址

以root用户创建目录

mkdir -p /usr/local/data

2、启动docker镜像

# 一些参数的说明
# docker run 
#     --name <docker_nname>    # 启动后容器的名称 
#     --restart=always 					# docker的自动重启
#     -v <data_address>:/var/lib/postgresql/data		# 数据卷挂载,前面的地址即为第一步创建的地址
#     -e POSTGRES_PASSWORD=<password>	# pgsql的密码
#     -p <port>:5432				# 端口映射,
#     -d  <image_id>				# 镜像名或ID

docker run --name mystl -e POSTGRES_PASSWORD=这里是你的密码 -p 1921:5432 -v /usr/local/data/postgres:/var/lib/postgresql/data -d postgres:14

3、备库从主库同步

进入容器

docker exec -it mystl bash
# 删除原数据
# 注:因为启动了docker自启动,删除文件目录,会导致容器退出,甚至报错无法再次进入
# 所以以下两步【删除数据,迁移数据】最好快速连续执行
# 也可以直接执行迁移数据的操作,确认报错是【文件已存在,无法迁移】后,再【删除】后【迁移】
rm -rf /var/lib/postgresql/data/*
# 迁移主库数据
pg_basebackup -R -D /var/lib/postgresql/data -P -h 你的主机IP -p 1922 -U replica
# 提示输入密码
这一步要快

# 出现以下代表数据迁移
26288/26288 kB (100%), 1/1 tablespace
# 退出docker
exit
exit
# 重启docker容器
docker restart mystl

在这里插入图片描述

tip:如果删除之后备库崩了,可以退出备库,docker restart mystl重启docker然后在进入备库

4、检查是否同步

# 在从库的</url/local/data/>存在postgresql.auto.conf文件,自动出现以下内容代表数据创建成功
cat postgresql.auto.conf

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'

在这里插入图片描述

五、测试主从数据库

主库:

在这里插入图片描述

备库:

在这里插入图片描述

到此这篇关于docker部署postgresSQL主从的方法步骤的文章就介绍到这了,更多相关docker部署postgresSQL主从内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • docker安装rocketMQ和安装过程中出现问题的解决

    docker安装rocketMQ和安装过程中出现问题的解决

    本文主要介绍了docker安装rocketMQ和安装过程中出现问题的解决,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • docker如何部署带有界面的registry仓库

    docker如何部署带有界面的registry仓库

    这篇文章主要介绍了docker如何部署带有界面的registry仓库问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-02-02
  • Docker搭建私有化仓库的几种方法

    Docker搭建私有化仓库的几种方法

    搭建 Docker 私有化仓库是一个非常重要的实践,它能够帮助你安全地存储和管理 Docker 镜像,本文主要介绍了Docker搭建私有化仓库的的几种方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-08-08
  • 使用docker部署php服务的详细步骤

    使用docker部署php服务的详细步骤

    Docker镜像是一个可移植的、自包含的单元,其中包含了运行应用程序所需的所有文件、配置和依赖项,当使用Docker部署PHP应用程序时,可以将PHP应用程序和其依赖项打包到一个称为Docker镜像的独立容器中,北本文介绍了使用docker部署php服务的详细步骤,需要的朋友可以参考下
    2024-03-03
  • Docker的安装与配置命令代码实例

    Docker的安装与配置命令代码实例

    这篇文章主要介绍了Docker的安装与配置命令代码实例,这是docker的基础知识点,有正在学习docker的同学可以研究下
    2021-03-03
  • Docker 镜像加速访问的几种方法

    Docker 镜像加速访问的几种方法

    本文介绍了DockerHub访问速度慢或不稳定时的替代方案,包括配置国内镜像源、使用一键脚本拉取镜像以及镜像导出与导入,感兴趣的可以了解一下
    2024-12-12
  • 详解Ubuntu16.04安装Docker、nvidia-docker的教程

    详解Ubuntu16.04安装Docker、nvidia-docker的教程

    这篇文章主要介绍了详解Ubuntu16.04安装Docker、nvidia-docker的教程,需要的朋友可以参考下
    2019-10-10
  • Docker Stack 部署web集群的方法步骤

    Docker Stack 部署web集群的方法步骤

    这篇文章主要介绍了Docker Stack 部署web集群的方法步骤,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • docker批量删除临时镜像

    docker批量删除临时镜像

    在开发的时候,需要经常发布开发包,在使用docker build构建镜像的时候,同一个版本经常会使用相同tag,频繁打包一段时间后,本地会出现很多Tag=<none>的临时镜像,下面给大家分享相关命令docker批量删除Tag=<none>的临时镜像,感兴趣的朋友一起看看吧
    2024-07-07
  • Docker打包SpringBoot镜像的实现方式

    Docker打包SpringBoot镜像的实现方式

    docker打包springboot镜像,并不是简单的将springboot项目的jar包上传容器里,然后启动,这个操作很简单,但是如果我每次要查看容器中的日志就需要每次都进入容器内部进行查看,这就非常麻烦了,所以本文介绍了Docker打包SpringBoot镜像的实现方式,需要的朋友可以参考下
    2024-03-03

最新评论