Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >聊聊PostgreSQL的Replication

聊聊PostgreSQL的Replication

作者头像
用户4700054
发布于 2022-08-17 04:42:49
发布于 2022-08-17 04:42:49
1.6K00
代码可运行
举报
运行总次数:0
代码可运行

CAP理论

  • consistency:在整个集群角度来看,每个节点是看到的数据一致的;不能出现集群中节点出现数据不一致的问题
  • vailability:集群中节点,只有有一个节点能提供服务
  • partitioning:集群中的节点之间网络出现问题,造成集群中一部分节点和另外一部分节点互相无法访问

基本术语

  • Master节点:提供数据写的服务节点
  • Standby节点:根据主节点(master节点)数据更改,这些更改同步到另外一个节点(standby节点)
  • Warm Standby节点:可以提升为master节点的standby节点
  • Hot Standby节点:主要提供读服务的standby节点
PostgreSQL支持的Replication方案
  • 基于文件或者磁盘Replication:这种方式采用共享磁盘或者共享NAS方式,采用了存储计算分离的方式,如果采用这样的方式,PostgreSQL是计算节点,底层的是一个分布式块存储或者分布式文件存储。这样的好处很明显,只需要保证计算层的高可用即可,但是弊端也很明显由于底层是分布式存储,PG性能取决于分布式文件存储。如果底层的分布式存储做的足够健壮,数据基本不会丢失
  • 基于wal的物理Replication:postgresql支持物理复制,其原理的就是先把Master节点的热备,然后传输到standby节点,在standby节点恢复;最后master不断的发送数据变更wal日志给standby节点,standby节点不断的接受wal日志,然后进行apply。物理复制是针对所有的Master节点上的databaase.由于wal是基于page的级别的,standby节点应用比较快,开销小。在物理复制中,Master节点会运行多个wal send进程;Standby节点会运行多个wal recv进程和startup进程,send是master发送wal日志的进程;recv进程是standby节点接受wal日志的进程,startup进程是standby节点apply wal日志的进程。
  • 基于SQL的逻辑Replication:基本原理是应用端发出更改请求,master不断的产生日志,紧接着master的send进程读取wal日志,然后经过decode模块进行解析wal日志转换为类似于sql的方式发送给standby的recv进程,recv进程接受到sql日志,发送给standby的execute模块进行解码成为sql语句,然后执行sql语句,产生wal日志。
Replication实践
物理复制
  • 准备两个PG实例
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 主节点 ip=127.0.0.1,port = 5432
// 从节点 ip=127.0.0.1,port = 5433
[perrynzhou@CentOS8-Dev /postgres]$ ps -ef|grep -v grep|grep postgre
perrynz+   13955       1  0 15:22 ?        00:00:00 /usr/local/postgres/bin/postgres -D /postgres/data1
perrynz+   13957   13955  0 15:22 ?        00:00:00 postgres: checkpointer 
perrynz+   13958   13955  0 15:22 ?        00:00:00 postgres: background writer 
perrynz+   13959   13955  0 15:22 ?        00:00:00 postgres: walwriter 
perrynz+   13960   13955  0 15:22 ?        00:00:00 postgres: autovacuum launcher 
perrynz+   13961   13955  0 15:22 ?        00:00:00 postgres: archiver 
perrynz+   13962   13955  0 15:22 ?        00:00:00 postgres: stats collector 
perrynz+   13963   13955  0 15:22 ?        00:00:00 postgres: logical replication launcher 
perrynz+   13966       1  0 15:22 ?        00:00:00 /usr/local/postgres/bin/postgres -D /postgres/data2
perrynz+   13968   13966  0 15:22 ?        00:00:00 postgres: checkpointer 
perrynz+   13969   13966  0 15:22 ?        00:00:00 postgres: background writer 
perrynz+   13970   13966  0 15:22 ?        00:00:00 postgres: walwriter 
perrynz+   13971   13966  0 15:22 ?        00:00:00 postgres: autovacuum launcher 
perrynz+   13972   13966  0 15:22 ?        00:00:00 postgres: stats collector 
perrynz+   13973   13966  0 15:22 ?        00:00:00 postgres: logical replication launcher
  • 在主节点创建复制账户和备份主节点
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 主库创建数据库用户
$ /usr/local/postgres/bin/psql  -h 127.0.0.1 postgres -p 5432 -U perrynzhou 
psql (14rc1)
Type "help" for help.

// 复制槽很重要,防止主库过早清理Wal
// 删除槽位信息 select pg_drop_replication_slot('slot_name');

postgres=# select * from pg_create_physical_replication_slot('db1_repl_slot');
   slot_name   | lsn 
---------------+-----
 db1_repl_slot | 
(1 row)

postgres=# select slot_name, slot_type, active, wal_status from pg_replication_slots;
   slot_name   | slot_type | active | wal_status 
---------------+-----------+--------+------------
 db1_repl_slot | physical  | f      | 
(1 row)


// 备份主库
$ /usr/local/postgres/bin/pg_basebackup --pgdata /postgres/master_backup --format=p \
   --write-recovery-conf --checkpoint=fast --label=mffb --progress \
   --host=127.0.0.1  --port=5432 --username=perrynzhou
166886/166886 kB (100%), 1/1 tablespace

// 停止从库
/usr/local/postgres/bin/pg_ctl -D /postgres/data2/ -l pg_logfile2 stop
// 删除从库数据库
rm -rf /postgres/data2 && mv /postgres/master_backup  /postgres/data2

 // 添加配置到从库的postgresql.conf
primary_conninfo = 'host=127.0.0.1 port=5432 user=perrynzhou password=zhoulin'
primary_slot_name = 'db1_repl_slot'
  • 主从配置
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 主库 postgresql.conf
port = 5432                             
max_connections = 100                   
shared_buffers = 128MB                 
dynamic_shared_memory_type = posix     
wal_level = replica
max_wal_size = 1GB
min_wal_size = 80MB
archive_mode = on
archive_command = 'cp %p /postgres/archive1/%f '
listen_addresses = '*'

//从库postgresql.conf
listen_addresses = '*'
archive_command = 'cp %p /postgres/archive2/%f '
port = 5433                             
max_connections = 100                
shared_buffers = 128MB                  
dynamic_shared_memory_type = posix     
max_wal_size = 1GB
min_wal_size = 80MB
wal_level = replica
hot_standby = on
max_standby_streaming_delay = 30s
hot_standby_feedback = on
primary_conninfo = 'host=127.0.0.1 port=5432 user=perrynzhou password=zhoulin'
primary_slot_name = 'db1_repl_slot'
  • 主从验证
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 主库
$ /usr/local/postgres/bin/psql  -h 127.0.0.1 postgres -p 5432 -U perrynzhou
psql (14rc1)

postgres=# create table tt1(id int);
CREATE TABLE
postgres=# insert into tt1 values(1);
INSERT 0 1
postgres=#

// 从库
$ /usr/local/postgres/bin/psql  -h 127.0.0.1 postgres -p 5433 -U perrynzhou
psql (14rc1)

postgres=# \d
         List of relations
 Schema | Name | Type  |   Owner    
--------+------+-------+------------
 public | tt1  | table | perrynzhou
(1 row)

postgres=# \t
Tuples only is on.
postgres=# select * from tt1;
  1

postgres=#
逻辑复制
  • 主从配置
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
port = 5432                             
max_connections = 100                   
shared_buffers = 128MB                 
dynamic_shared_memory_type = posix     
wal_level = logical
max_wal_size = 1GB
min_wal_size = 80MB
archive_mode = on
archive_command = 'cp %p /postgres/archive1/%f '
listen_addresses = '*'

//从库postgresql.conf
listen_addresses = '*'
archive_command = 'cp %p /postgres/archive2/%f '
port = 5433                             
max_connections = 100                
shared_buffers = 128MB                  
dynamic_shared_memory_type = posix     
max_wal_size = 1GB
min_wal_size = 80MB
wal_level = replica
hot_standby = on
max_standby_streaming_delay = 30s
hot_standby_feedback = on
primary_conninfo = 'host=127.0.0.1 port=5432 user=perrynzhou password=zhoulin'
primary_slot_name = 'db1_repl_slot'
  • 配置主库和从库
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 配置主库
$ /usr/local/postgres/bin/psql  -h 127.0.0.1 postgres -p 5432 -U perrynzhou
psql (14rc1)

postgres=# CREATE PUBLICATION my_publication FOR ALL TABLES;
CREATE PUBLICATION
postgres=# 

// 配置从库
$ /usr/local/postgres/bin/psql  -h 127.0.0.1 postgres -p 5433 -U perrynzhou
psql (14rc1)

postgres=# CREATE SUBSCRIPTION my_subscription CONNECTION 'host=127.0.0.1 port=5432 user=perrynzhou dbname=postgres' PUBLICATION my_publication WITH (copy_data=false);
NOTICE:  created replication slot "my_subscription" on publisher
CREATE SUBSCRIPTION
  • 验证
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 主库插入数据
$ /usr/local/postgres/bin/psql  -h 127.0.0.1 postgres -p 5432 -U perrynzhou
postgres=# select * from tt2;
 id 
----
(0 rows)

postgres=# insert into tt2 values(100);
INSERT 0 1

// 从库查看数据
[perrynzhou@CentOS8-Dev /postgres]$ /usr/local/postgres/bin/psql  -h 127.0.0.1 postgres -p 5433 -U perrynzhou
postgres=# select * from tt2;
 id  
-----
 100
(1 row)

postgres=# 

// 主库查看复制槽位信息
postgres=# select slot_name, slot_type, active, wal_status from pg_replication_slots;
    slot_name    | slot_type | active | wal_status 
-----------------+-----------+--------+------------
 my_subscription | logical   | t      | reserved
(2 rows)
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-12-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 存储内核技术交流 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Postgresql总结几种HA的部署方式
第二步:pg_basebackup -Fp -P -x -D ~/app/data/pg_root21 -l basebackup21
mingjie
2022/05/12
1.6K0
Postgresql总结几种HA的部署方式
【DB宝62】PG高可用之repmgr(1主2从+1witness)+Pgpool-II实现主从切换+读写分离+负载均衡
第二次执行时不再提示输入yes,并且可以成功执行命令,则表示SSH对等性配置成功。
AiDBA宝典
2021/07/29
1.8K1
Postgresql主从复制--物理复制
PostgreSQL支持物理复制(流复制)及逻辑复制2种。通过流复制技术,可以从实例级复制出一个与主库一模一样的实例级的从库。流复制同步方式有同步、异步两种。
俊才
2019/09/26
6.8K0
进阶数据库系列(二十一):PostgreSQL 数据目录同步工具 pg_rewind
pg_rewind 相比 pg_basebackup 和 rsync 这样的工具来说,优势是它不需要从源目录拷贝所有的数据文件,而是会对比时间线发生偏离的点,只拷贝变化过的文件,这样对于数据量很大的情况下速度更快。
民工哥
2023/08/22
2K0
进阶数据库系列(二十一):PostgreSQL 数据目录同步工具 pg_rewind
【DB宝60】PG12高可用之1主2从流复制环境搭建及切换测试
PostgreSQL在9.x之后引入了主从的流复制机制,所谓流复制,就是备服务器通过tcp流从主服务器中同步相应的数据,主服务器在WAL记录产生时即将它们以流式传送给备服务器,而不必等到WAL文件被填充。
AiDBA宝典
2021/07/29
3.3K0
【DB宝91】PG高可用之主从流复制+keepalived 的高可用
通过keepalived 来实现 PostgreSQL 数据库的主从自动切换,以达到高可用。当主节点宕机时,从节点可自动切换为主节点,继续对外提供服务。
AiDBA宝典
2022/02/23
2.9K0
【DB宝91】PG高可用之主从流复制+keepalived 的高可用
PostgreSQl 12主从流复制及归档配置
上一篇文章说道PostgreSQL 12 的源码部署,这里我们说一下PostgreSQl 12的主从流复制和归档配置。
没有故事的陈师傅
2022/02/09
2.6K0
PostgreSQL主从复制--逻辑复制
逻辑复制是基于逻辑解析,其核心原理是逻辑主库将Publication中表的WAL日志解析成一定格式并发送给逻辑备库,逻辑备库Subscription接收到解析后的WAL日志后进行重做,从而实现表数据同步。
俊才
2019/10/14
4.6K0
PostgreSQL主从复制--逻辑复制
【DB宝72】pgpool-II和pgpoolAdmin的使用
但是,之前的文章中没有介绍有关pgpoolAdmin的知识,这款针对pgpool开发的web界面工具,还是比较实用的。
AiDBA宝典
2021/12/17
3.4K0
【DB宝72】pgpool-II和pgpoolAdmin的使用
pg9.5升级 到 pg11 的步骤
-bash-4.2$ egrep "^\w+" postgresql.conf  参数如下:
保持热爱奔赴山海
2019/09/17
1.1K0
PG高可用之repmgr(1主2从+1witness)+Pgpool-II实现主从切换+读写分离+负载均衡
第二次执行时不再提示输入yes,并且可以成功执行命令,则表示SSH对等性配置成功。
AiDBA宝典
2022/11/07
3.1K0
PG高可用之repmgr(1主2从+1witness)+Pgpool-II实现主从切换+读写分离+负载均衡
PostgresSQL 主从搭建步骤
由于工作需要,最近开始接触各种数据库,并尝试各种数据库产品的高可用方案。今天分享的是postgresSQL的主从配置,其实还是蛮简单的,跟随本文的步骤,保证能实现PG主从的搭建。
星哥玩云
2022/08/13
2.5K0
用Keepalived实现PostgreSQL高可用
Keepalived可提供VRRP以及health-check功能,可以只用它提供双机浮动的vip(VRRP虚拟路由功能),这样可以简单实现一个双机热备高可用功能。
数据和云
2021/10/28
3.2K0
用Keepalived实现PostgreSQL高可用
PostgreSQL从小白到高手教程 - 第44讲:pg流复制部署
PostgreSQL从小白到专家,是从入门逐渐能力提升的一个系列教程,内容包括对PG基础的认知、包括安装使用、包括角色权限、包括维护管理、、等内容,希望对热爱PG、学习PG的同学们有帮助,欢迎持续关注CUUG PG技术大讲堂。
用户5892232
2024/02/02
4820
PostgreSQL从小白到高手教程 - 第44讲:pg流复制部署
【Linux】PostgreSQL 主从模式部署(源码编译方式)
近期,笔者承接了在 Linux 操作系统下部署 PostgreSQL 主从模式的需求,且客户要求必须是非容器化部署。
行者Sun
2024/09/02
4530
【Linux】PostgreSQL 主从模式部署(源码编译方式)
[译]PG复制和自动故障转移--2
6)通过pg_waldump --path=/tmp/sd/pg_wal -start=0/1C420B8看下日志文件里内容。使用的是步骤3中的起始LSN。注意WAL中包含创建物理文件的指令:
yzsDBA
2022/04/28
7150
[译]PG复制和自动故障转移--2
POSTGRESQL 主节点失败后, 在多变的情况下重新让他融入复制中
POSTGRESQL 在主从流复制中,在主库失败切换后,从库变为主库后,如果主库不是因为硬件的原因,想继续拉起来,并且加入到新的复制关系中,一般都会通过pg_rewind的程序来进行拉起来. 但不少问题反馈对pg_rewind在重新拉起旧主库出现问题,到底有什么情况下pg_rewind对你的数据库重新建立复制关系"力不从心", 怎么去避免这样的情况是这篇文字要讨论和提到的.
AustinDatabases
2021/09/02
1.7K0
原 使用pg_basebackup搭建PostgreSQL流复制环境
环境:     OS: [ha@node0 ~]$ uname -a Linux node0 2.6.32-358.el6.x86_64 #1 SMP Fri Feb 22 00:31:26 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux     内存:1G     CPU:1核     数据库: postgres=# select version();
王果壳
2018/05/17
1.1K0
docker 部署 postgresql的主从数据库
docker exec -it -u postgres pgsslave /bin/bash
liuyunshengsir
2021/09/17
1.9K0
--PostgreSQL 来自欧罗巴Patroni Patroni 配置文件 4
作为关于Patroni 的第四篇文字, 总想有些深度, 那深度是从哪里而来,首先我们先从patroni 运行后,在系统中存储的键值入手.
AustinDatabases
2020/10/30
1.2K0
--PostgreSQL  来自欧罗巴Patroni   Patroni  配置文件  4
推荐阅读
相关推荐
Postgresql总结几种HA的部署方式
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验