一、主从规划
因为就一台服务器,所以两台服务器的ip是一样的,我采用了不同的端口
IP地址 | 名称 | 备注 |
---|
x.x.x.x:1922 | mymaster | 主库 |
x.x.x.x:1921 | mystl | 备库 |
需要提前配置好Docker容器
二、创建PostgresSQL的Docker镜像

查看镜像是否创建成功

三、主库部署
1、建立pgsql主库的data地址
以root用户创建目录
1 | mkdir -p /usr/local/datamaster
|
2、启动docker镜像
1 2 3 4 5 6 7 8 9 10 | docker run - -name mymaster -e POSTGRES_PASSWORD=这里是你的密码 -p 1922:5432 -v /usr/local/datamaster/postgres:/var/lib/postgresql/data -d postgres:14
|

查看数据库是否创建成功

记住名称,后边要用
3、docker内操作
1 2 3 4 5 | docker exec -it mymaster bash
su postgres
psql
|

1 2 3 4 5 6 7 | CREATE ROLE replica login replication encrypted password '这里是你的密码!' ;
\du
exit
exit
|

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

/usr/local/datamaster/postgres/arc 必须存在,如果不存在,则也需要mkdir一次
1 2 | mkdir -p /usr/local/datamaster/postgres/arc
chmod 777 /usr/local/datamaster/postgres/arc
|
1 2 3 4 5 6 7 8 9 10 11 12 | 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
listen_addresses = '*'
max_connections = 100
|




1 2 3 4 | vim pg_hba.conf
host replication replica 172.0.0.0/8 md5
|

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

四、部署从数据库
1、建立psql备库的data地址
以root用户创建目录
2、启动docker镜像
1 2 3 4 5 6 7 8 9 10 | 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 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | 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
exit
exit
docker restart mystl
|

tip:如果删除之后备库崩了,可以退出备库,docker restart mystl
重启docker然后在进入备库
4、检查是否同步
1 2 3 4 5 | 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'
|

五、测试主从数据库
主库:

备库:
