postgresql主从复制

用vmware 搭建的两台虚拟机

操作系统:Ubuntu 24.04 Server版

数据库:postgresql 16.2

主库:192.168.2.11

从库:192.168.2.12

如果遇到网络无法上网,可参考一下 Vmware 搭建的Ubuntu 24.04 网络配置-CSDN博客

1.两台服务器安装数据库

Ubuntu 24.04默认有postgresql 16.2的数据库,

复制代码
sudo apt-get install postgresql-16
2.主库 192.168.2.1
登陆到postgresql

参数说明:-u postgre 使用postgres用户 执行psql命令(不然很大可能会报无权限)

bash 复制代码
sudo -u postgres psql -U postgres 
创建用于主从复制的角色

参数说明

login:这个选项允许登录到数据库;

replication:这个选项赋予角色复制权限

encrypted:这个选项指示数据库在存储密码时应该使用加密方式

sql 复制代码
create role replica1 login replication encrypted password 'replica1';
修改pg_hba.conf文件
bash 复制代码
 sudo vim /etc/postgresql/16/main/pg_hba.conf

在原来的基础上新增以下行:主要是为了允许备库(192.168.2.2)访问主库

host replication replica1 192.168.2.2/24 md5

host all postgres 192.168.2.2/24 trust

修改postgresql.conf文件
bash 复制代码
sudo vim /etc/postgresql/16/main/postgresql.conf

参数说明可以参考一下:

20.6. 复制 (postgres.cn)

PostgresqlCO.NF: PostgreSQL configuration for humans

listen_addresses = '*'

max_connections = 100

wal_level = replica

max_wal_senders = 10

wal_keep_size = 64

wal_sender_timeout = 60

配置好之后重启服务

bash 复制代码
sudo service postgresql restart
3.备库 192.168.2.2
登陆到postgresql
bash 复制代码
sudo -u postgres psql -U postgres 
创建用于主从复制的角色
sql 复制代码
create role replica1 login replication encrypted password 'replica1';
修改pg_hba.conf文件
bash 复制代码
 sudo vim /etc/postgresql/16/main/pg_hba.conf

在原来的基础上新增以下行:主要是为了允许主库(192.168.2.1)访问备库(用于主库宕机后,通过连接备库同步最新数据)

host replication replica1 192.168.2.1/24 md5

host all postgres 192.168.2.1/24 trust

修改postgresql.conf文件
bash 复制代码
sudo vim /etc/postgresql/16/main/postgresql.conf

listen_addresses = '*'

max_connections = 120 #这个参数要比主库的大一点

max_wal_senders = 10

wal_keep_size = 64

wal_sender_timeout = 60

配置好之后重启服务

bash 复制代码
sudo service postgresql restart

从主库中备份数据:

bash 复制代码
pg_basebackup -h 192.168.2.1  -D /var/lib/postgresql/16/main -p 5432 -U replica1 -Fp -Xs -Pv -R --checkpoint=fast

备份完成后修改postgresql.auto.conf文件

bash 复制代码
su postgres
vim /var/lib/postgresql/16/main/ postgresql.auto.conf

postgresql.auto.conf

primary_conninfo = 'user=replica1 password=replica1 host=192.168.2.1 port=5432'

recovery_target_timeline = latest

hot_standby = on

max_standby_streaming_delay = 30s

wal_receiver_status_interval = 10s

hot_standby_feedback = on

max_connections = 120

4.试验

分别在主库、备库测试一下能不能相互连接:

备库执行:

bash 复制代码
sudo -u postgres psql -h 192.168.2.1 -U postgres

主库执行:

bash 复制代码
sudo -u postgres psql -h 192.168.2.2 -U postgres

如果都能相互连通,那么就可以进行下一步操作

在192.168.2.1上创建数据库 create database testdb1;看看在192.168.2.2上是否同步;

模拟192.168.2.1 宕机

192.168.2.1上执行,停止服务

bash 复制代码
sudo service postgresql stop

在 192.168.2.2执行,把192.168.2.2提升为主服务:

bash 复制代码
pg_ctl promote -D $PGDATA 

如果找不到pg_ctl和$PGDATA,则使用

bash 复制代码
 /usr/lib/postgresql/16/bin/pg_ctl promote -D /var/lib/postgresql/16/main

在192.168.2.1执行,切换到postgres用户,删除/var/lib/postgresql/16/main下的所有文件

bash 复制代码
su postgres
cd /var/lib/postgresql/16/main
rm -rf *

pg_basebackup -h 192.168.2.2  -p 5432 -U postgres -D /var/lib/postgresql/16/main -Fp -P -Xs -R -v -l postgresbak

执行完上面步骤后,可以在192.168.2.1看到数据同步了过来,但这个时候192.168.2.1是备库,数据库是处于只读状态的,而192.168.2.2属于主库。如果想把192.168.2.1又变成主库,可以在192.168.2.1上执行pg_ctl promote -D $PGDATA

相关推荐
shengli72239 分钟前
Python在金融科技(FinTech)中的应用
jvm·数据库·python
xcLeigh40 分钟前
IoTDB Python原生接口全攻略:从基础读写到高级实战
开发语言·数据库·python·api·iotdb·原生接口·读写数据
xcLeigh1 小时前
Python操作国产金仓数据库(KingbaseES)全流程:从环境搭建到实战应用
开发语言·数据库·python·国产数据库·kingbasees·金仓数据库
人道领域2 小时前
Day | 11 【苍穹外卖统计业务的实现:含详细思路分析】
java·数据库·后端·苍穹外卖
ZTLJQ8 小时前
数据的基石:Python中关系型数据库完全解析
开发语言·数据库·python
升鲜宝供应链及收银系统源代码服务9 小时前
《IntelliJ + Claude Code + Gemini + ChatGPT 实战配置手册升鲜宝》
java·前端·数据库·chatgpt·供应链系统·生鲜配送
跟着珅聪学java9 小时前
js编写中文转unicode 教程
前端·javascript·数据库
小江的记录本9 小时前
【Redis】Redis全方位知识体系(附《Redis常用命令速查表(完整版)》)
java·数据库·redis·后端·python·spring·缓存
还是做不到嘛\.10 小时前
Dvwa靶场-SQL Injection
数据库·sql·web安全
楼田莉子10 小时前
MySQL数据库:MySQL的数据类型
数据库·学习·mysql