使用tunnel同步PG数据到kafka
admin
2023-03-02 09:22:14
0

tunnel同步PG数据到kafka

来自哈罗单车开源的组件。支持同步PG数据到kafka或者ES。


 

https://github.com/hellobike/tunnel

 

tunnel整体的部署比较简单的

需要事先部署好zkkafka(我下面演示的是单节点的zkkafka

 

节点部署关系:

192.168.2.4   部署zkkafkapg10运行在1921端口

192.168.2.189 部署tunnel

 

 

确保已开启PG的逻辑复制

wal_level = 'logical';

max_replication_slots = 20

注意这个设置要重启PG进程的

 

然后,创建测试库表和同步用的账号

CREATE DATABASE test_database;

\c test_database

create table test_1 (id int primary key , name char(40));

create table test_2 (id int primary key , name char(40));

 

CREATE ROLE test_rep LOGIN ENCRYPTED PASSWORD 'xxxx' REPLICATION;

GRANT CONNECT ON DATABASE test_database to test_rep;

 

vim pg_hba.conf 增加2行配置:

host    all                   test_rep        192.168.2.0/24         md5

host    replication     test_rep        192.168.2.0/24         md5

然后 reload PG

 

192.168.2.189 机器上去 编译tunnel

注意: tunnel的启动需要事先安装好oracle jdk 1.8

 

git clone https://github.com/hellobike/tunnel

cd tunnel

mvn clean package -Dmaven.test.skip=true

cd target

unzip AppTunnelService.zip

cd AppTunnelService

 

vim conf/test.yml 内容如下:

tunnel_subscribe_config:

  pg_dump_path: '/usr/local/pgsql-10.10/bin/pg_dump'

  subscribes:

  - slotName: slot_for_test

    pgConnConf:

      host: 192.168.2.4

      port: 1921

      database: test_database

      user: test_rep

      password: xxxx

    rules:

    - {table: test_1, pks: ['id'], topic: test_1_logs}

    - {table: test_2, pks: ['id'], topic: test_2_logs}

    kafkaConf:

      addrs:

      - 192.168.2.4:9092

tunnel_zookeeper_address: 192.168.2.4:2181

 

前台启动:

java -server -classpath conf/*:lib/* com.hellobike.base.tunnel.TunnelLauncher -u false -c cfg.properties -p 7788     # 暴露prometheus metric7788端口(配置监控不是这里的重点,也很简单,暂时先跳过)


然后,我们再在PG10上面的test_database2张表随便造些数据,然后可以看到kafka里面已经有数据了(下图是通过kafkamanager kafka-eagle的结果)。

使用tunnel同步PG数据到kafka



使用tunnel同步PG数据到kafka



格式化下,数据就是这样的:

UPDATE的记录的样子:

{

         "dataList": [{

                   "dataType": "integer",

                   "name": "id",

                   "value": "1111"

         }, {

                   "dataType": "character",

                   "name": "name",

                   "value": "大狗蛋 "

         }],

         "eventType": "UPDATE",

         "lsn": 10503246616,

         "schema": "public",

         "table": "test_1"

}

 

DELETE的记录的样子:

{

         "dataList": [{

                   "dataType": "integer",

                   "name": "id",

                   "value": "3"

         }],

         "eventType": "DELETE",

         "lsn": 10503247064,

         "schema": "public",

         "table": "test_1"

}

相关内容

热门资讯

终于明白“海岛互娱.辅助开挂神... 终于明白“海岛互娱.辅助开挂神器?”确实真的有挂您好,海岛互娱这个游戏其实有挂的,确实是有挂的,需要...
【第一财经】“新好游炸金花.辅... 【第一财经】“新好游炸金花.辅助开挂神器?”其实是有挂您好,新好游炸金花这个游戏其实有挂的,确实是有...
多个省份警方破获用无人机投射箭... 澎湃新闻记者 张未央起飞热成像无人机,发现野生动物后投射箭矢,或抛投捕兽网、金属球等——近期多个省份...
今日重大通报“全民游戏.真的有... 今日重大通报“全民游戏.真的有挂吗?”详细开挂教程您好,全民游戏这个游戏其实有挂的,确实是有挂的,需...
【今日要闻】“白金岛游戏.辅助... 网上科普关于“白金岛游戏有没有挂”话题很是火热,小编也是针对白金岛游戏作*弊开挂的方法以及开挂对应的...
【第一消息】“战皇炸金花.到底... 网上科普关于“战皇炸金花有没有挂”话题很是火热,小编也是针对战皇炸金花作*弊开挂的方法以及开挂对应的...
终于了解“元来黄冈麻将.有挂吗... 终于了解“元来黄冈麻将.有挂吗?”其实是有挂您好,元来黄冈麻将这个游戏其实有挂的,确实是有挂的,需要...
最新引进“新蛮王牛牛.辅助开挂... 网上科普关于“新蛮王牛牛有没有挂”话题很是火热,小编也是针对新蛮王牛牛作*弊开挂的方法以及开挂对应的...
覆盖备孕到6岁的孕育APP,长... 核心区别概述 妈妈网、宝宝树和亲宝宝作为母婴类应用,在多个维度上表现出差异。这些差异主要体现在用户覆...
终于明白“桃花庄.怎么开挂?”... 家人们!今天小编来为大家解答桃花庄透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很多...