在docker上部署postgresSQL主从
创始人
2024-12-17 22:39:24
0

文章目录

  • 一、主从规划
  • 二、创建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     # 启动后容器的名称  #     --restart=always 					# docker的自动重启 #     -v :/var/lib/postgresql/data		# 数据卷挂载,前面的地址即为第一步创建的地址 #     -e POSTGRES_PASSWORD=	# pgsql的密码 #     -p :5432				# 端口映射, #     -d  				# 镜像名或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 
# 修改/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 

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

# 修改/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     # 启动后容器的名称  #     --restart=always 					# docker的自动重启 #     -v :/var/lib/postgresql/data		# 数据卷挂载,前面的地址即为第一步创建的地址 #     -e POSTGRES_PASSWORD=	# pgsql的密码 #     -p :5432				# 端口映射, #     -d  				# 镜像名或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、检查是否同步

# 在从库的存在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' 

在这里插入图片描述

五、测试主从数据库

主库:
在这里插入图片描述
备库:
在这里插入图片描述

相关内容

热门资讯

教学盘点!蜜瓜大厅小程序辅助,... 教学盘点!蜜瓜大厅小程序辅助,新超凡大厅怎么开挂,爆料教程(有挂规律)是一款可以让一直输的玩家,快速...
一分钟了解!518互游辅助器下... 一分钟了解!518互游辅助器下载(辅助挂)竟然有开挂辅助神器(了解有挂)1、518互游辅助器下载机器...
玩家必看!微乐自建房插件详细教... 玩家必看!微乐自建房插件详细教程,微信雀神小程序插件,技巧教程(有挂细节);1、不需要AI权限,帮助...
必看攻略!家乡大二辅助免费(辅... 必看攻略!家乡大二辅助免费(辅助挂)本然有开挂辅助安装(有挂解惑);1、许多玩家不知道家乡大二辅助免...
玩家必备科技!来来拼十软件脚本... 您好,来来拼十软件脚本这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在...
新手必备!传送屋激k辅助器(辅... 新手必备!传送屋激k辅助器(辅助挂)竟然有开挂辅助脚本(有挂解密)1、传送屋激k辅助器ai辅助优化,...
盘点十款!微信小程序微乐安徽辅... 盘点十款!微信小程序微乐安徽辅助苹果,神雀小程序游戏破解器,必胜教程(有挂规律);微信小程序微乐安徽...
一秒答解!皮皮衡阳字牌黑科技视... 一秒答解!皮皮衡阳字牌黑科技视频(辅助挂)固有有开挂辅助神器(有挂细节)是一款可以让一直输的玩家,快...
透视能赢!游戏挂机辅助软件(辅... 透视能赢!游戏挂机辅助软件(辅助挂)切实有开挂辅助工具(证实有挂)所有人都在同一条线上,像星星一样排...
盘点几款!玖游卡五星辅助,玄龙... 盘点几款!玖游卡五星辅助,玄龙辅助下载,力荐教程(有挂解密)是一款可以让一直输的玩家,快速成为一个“...