在docker上部署postgresSQL主从

2024-05-24 18:12

本文主要是介绍在docker上部署postgresSQL主从,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一、主从规划
  • 二、创建PostgresSQL的Docker镜像
  • 三、主库部署
    • 1、建立pgsql主库的data地址
    • 2、启动docker镜像
    • 3、docker内操作
    • 4、修改配置文件
  • 四、部署从数据库
    • 1、建立psql备库的data地址
    • 2、启动docker镜像
    • 3、备库从主库同步
    • 4、检查是否同步
  • 五、测试主从数据库

一、主从规划

因为就一台服务器,所以两台服务器的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>				# 镜像名或IDdocker 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.confarchive_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>				# 镜像名或IDdocker 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.confprimary_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主从的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/999150

相关文章

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

查看MySql主从同步的偏移量方式

《查看MySql主从同步的偏移量方式》:本文主要介绍查看MySql主从同步的偏移量方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 1.mysql的主从同步方案mysqlphp为了在实现读写分离,主库写,从库读mysql的同步方案主要是通过从库读取主库的binl

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

ubuntu如何部署Dify以及安装Docker? Dify安装部署指南

《ubuntu如何部署Dify以及安装Docker?Dify安装部署指南》Dify是一个开源的大模型应用开发平台,允许用户快速构建和部署基于大语言模型的应用,ubuntu如何部署Dify呢?详细请... Dify是个不错的开源LLM应用开发平台,提供从 Agent 构建到 AI workflow 编排、RA

ubuntu16.04如何部署dify? 在Linux上安装部署Dify的技巧

《ubuntu16.04如何部署dify?在Linux上安装部署Dify的技巧》随着云计算和容器技术的快速发展,Docker已经成为现代软件开发和部署的重要工具之一,Dify作为一款优秀的云原生应用... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。它

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

Docker安装MySQL镜像的详细步骤(适合新手小白)

《Docker安装MySQL镜像的详细步骤(适合新手小白)》本文详细介绍了如何在Ubuntu环境下使用Docker安装MySQL5.7版本,包括从官网拉取镜像、配置MySQL容器、设置权限及内网部署,... 目录前言安装1.访问docker镜像仓库官网2.找到对应的版本,复制右侧的命令即可3.查看镜像4.启