暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

专栏 | PostgreSQL数据实时同步在哈啰的实践

背景
随着业务的发展,对于实时报表、数据实时搜索、集群同步的需求越来越旺盛,例如多业务的订单搜索、实时统计等。从PostgreSQL实时同步的开源方案主要有bottledwater-pg、Postgres_fdw等,开源的方案中基本处于缺乏维护状态,支持的功能也比较弱,为此哈啰实现了一套基于PostgreSQL逻辑复制槽的实时同步平台Tunnel。
架构设计
PG数据同步的实现原理
replication slots 是从PostgreSQL 9.4开始引入的,引入后我们可以基于复制槽实现更多的迁移同步需求。replication slots保存了逻辑或物理流复制的基础信息。类似MySQL的位点信息。一个逻辑slot创建后,它的相关信息可以通过pg_replication_slots系统视图获取。如果slot为active状态,则可以通过系统视图pg_stat_replication看到slot的实时的状态信息。PostgreSQL的逻辑日志来源于解析WAL日志。
解析WAL成为逻辑数据的过程叫Logical Decoding。Logical Decoding是把WAL日志解析成逻辑日志的过程。这个过程输出的数据格式可以描述为:
1、事务开始任何的变化总是在一个事务中,所以订阅的数据变化的开始是一个事务被启动的消息,他包括了事务ID、LSN、开始时间等信息。
2、数据的变化包括当前事务中修改的数据。即对某些表的insert/update/delete操作来带的数据变化。
  • 一个事务内可以包含任意个表和任意行数据的变化。
  • 输出的数据的格式和对应表的定义和REPLICA IDENTITY相关。
3、事务的提交包括事务提交的 LSN、时间等相关信息。
逻辑流复制利用索引的方式优化传输数据的效率,它们可以按表为单位定制。大致分为三种情况:
  1. 如果修改的表有primary key, 则表的变化的逻辑数据只会包括该表变化的列和pk列数据,如果pk列被修改,则还会输出老的pk列数据。
  2. 如果修改的表没有primary key,则可以使用alter table指定一个REPLICA index,同时需要这个索引列为非空,其产生的效果和1相同。
  3. 如果修改的表不满足上面的两个条件,而又要做同步,可以使用alter table设置这个表的REPLICA IDENTITY为FULL。于是系统在表修改时会记录修改行的所有列,不会做任何的优化。
同步任务的自动下发
同步任务进行申请配置后,任务下发到同步节点整体依赖zookeeper来实现,基于zookeeper的通知机制实现配置的变化监听,从管理节点获取到同步任务信息,执行相应的同步。为了平衡同步节点,通过监控计算同步节点最近有效的同步tps,然后按照贪心算法选择tps最小的任务节点进行下发。
同步任务的高可用

同步任务的高可用也是基于zookeeper实现而成,同步任务节点启动初始化时将机器节点信息注册至zookeeper,同步管理节点监听注册的机器节点,当机器节点发生down机或异常挂掉后,注册至zookeeper的临时节点将发生变更,管理节点监听变化后读取该节点执行的同步任务,将该任务下发至其他可工作的节点。下发时存在下发失败的可能性,需做好下发队列的重试工作。

同步数据的一致性
保证同步数据不丢失主要依赖以下两个方案:
  • 通过复制槽的confirmed_flush_lsn进行消费数据成功的确认,confirmed_flush_lsn是逻辑插槽的consumer已确认接收数据的地址(LSN),超过此时间的数据将不再可用。

  • 数据发送至kafka,发送成功后flush lsn,通过自动创建消费kafka的任务同步至其他数据源,如ES、Hbase、Hive等,保证同步服务的性能与可靠性。

同步配置规则
  1. 利用正则表达式对表名进行匹配,满足分库分表或一定规则的通用配置
  2. 只匹配需要的字段,对于敏感字段进行过滤
  3. 指定并匹配主键
开源版本地址
https://github.com/hellobike/tunnel
总结与展望
做为数据实时同步的基础,同步平台Tunnel已覆盖使用各业务线同步数据的使用场景,实现数据的实时、准确、高效的同步。在后面的计划中将实现数据的更加可靠的有序性,跨机房数据的同步等功能,从而更加稳定的支持业务的发展。


技术文章精彩回顾




PostgreSQL学习的九层宝塔
PostgreSQL职业发展与学习攻略
搞懂PostgreSQL数据库透明数据加密之加密算法介绍
一文读懂PostgreSQL-12分区表
PostgreSQL源码学习之:RegularLock
Postgresql源码学习之词法和语法分析
PostgreSQL buffer管理
最佳实践—PG数据库系统表空间重建
PostgreSQL V12中的流复制配置
2019,年度数据库舍 PostgreSQL 其谁?
PostgreSQL使用分片(sharding)实现水平可扩展性
一文搞懂PostgreSQL物化视图
PostgreSQL原理解析之:PostgreSQL备机是否做checkpoint
PostgreSQL复制技术概述

PG活动精彩回顾




见证精彩|PostgresConf.CN2019大会盛大开幕
PostgresConf.CN2019大会DAY2|三大分论坛,精彩不断
PostgresConf.CN2019培训日|爆满!Training Day现场速递!
「PCC-Training Day」培训日Day2圆满结束,PCC2019完美收官
创建PG全球生态!PostgresConf.CN2019大会盛大召开
首站起航!2019“让PG‘象’前行”上海站成功举行
走进蓉城丨2019“让PG‘象’前行”成都站成功举行
中国PG象牙塔计划发布,首批合作高校授牌仪式在天津举行
PostgreSQL实训基地落户沈阳航空航天大学和渤海大学,高校数据库课改正当时
群英论道聚北京,共话PostgreSQL
相聚巴厘岛| PG Conf.Asia 2019  DAY0、DAY1简报
相知巴厘岛| PG Conf.Asia 2019 DAY2简报
相惜巴厘岛| PG Conf.Asia 2019 DAY3简报
独家|硅谷Postgres大会简报
全球规模最大的PostgreSQL会议等你来!

PG培训认证精彩回顾




关于中国PostgreSQL培训认证,你想知道的都在这里!
首批中国PGCA培训圆满结束,首批认证考试将于10月18日和20日举行!
中国首批PGCA认证考试圆满结束,203位考生成功获得认证!
中国第二批PGCA认证考试圆满结束,115位考生喜获认证!
请查收:中国首批PGCA证书!
重要通知:三方共建,中国PostgreSQL认证权威升级!
一场考试迎新年 | 12月28日,首次PGCE中级认证考试开考!
近500人参与!首次PGCE中级、第三批次PGCA初级认证考试落幕!


文章转载自开源软件联盟PostgreSQL分会,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论