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

相关推荐
Databend29 分钟前
Databend 亮相 RustChinaConf 2025,分享基于 Rust 构建商业化数仓平台的探索
数据库
得物技术1 小时前
破解gh-ost变更导致MySQL表膨胀之谜|得物技术
数据库·后端·mysql
Raymond运维6 小时前
MariaDB源码编译安装(二)
运维·数据库·mariadb
沢田纲吉6 小时前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql
RestCloud21 小时前
SQL Server到Hive:批处理ETL性能提升30%的实战经验
数据库·api
RestCloud1 天前
为什么说零代码 ETL 是未来趋势?
数据库·api
ClouGence1 天前
CloudCanal + Paimon + SelectDB 从 0 到 1 构建实时湖仓
数据库
DemonAvenger1 天前
NoSQL与MySQL混合架构设计:从入门到实战的最佳实践
数据库·mysql·性能优化
AAA修煤气灶刘哥2 天前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
RestCloud2 天前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api