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

相关推荐
woshilys12 分钟前
sql server 查询对象的修改时间
运维·数据库·sqlserver
Hacker_LaoYi13 分钟前
SQL注入的那些面试题总结
数据库·sql
建投数据1 小时前
建投数据与腾讯云数据库TDSQL完成产品兼容性互认证
数据库·腾讯云
Hacker_LaoYi2 小时前
【渗透技术总结】SQL手工注入总结
数据库·sql
岁月变迁呀2 小时前
Redis梳理
数据库·redis·缓存
独行soc2 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍06-基于子查询的SQL注入(Subquery-Based SQL Injection)
数据库·sql·安全·web安全·漏洞挖掘·hw
你的微笑,乱了夏天3 小时前
linux centos 7 安装 mongodb7
数据库·mongodb
工业甲酰苯胺3 小时前
分布式系统架构:服务容错
数据库·架构
独行soc4 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘
White_Mountain4 小时前
在Ubuntu中配置mysql,并允许外部访问数据库
数据库·mysql·ubuntu