PG逻辑复制槽应用

=pg_recvlogical使用===

pg_recvlogical -d postgres -U aaron --slot=test_database --start -f recv.sql

pg_logical_slot_get_changes()函数展示解析数据并消费掉;

pg_logical_slot_peek_changes()函数展示解析数据不会消费掉;

pg_recvlogical,pg自带的工具,能消费复制槽内的数据,相当于逻辑复制的下游。对应物理wal接收工具为 pg_receivewal

=创建复制槽===

SELECT pg_create_logical_replication_slot('logical_test', 'test_decoding');

select * from pg_logical_slot_peek_changes('logical_test',null,null);

select * from pg_logical_slot_get_changes('logical_test',null,null);

select pg_replication_slot_advance();推进复制槽

SELECT pg_drop_replication_slot('slot_name');

发布订阅==

订阅发布默认走的pgoutput解析插件。

CREATE PUBLICATION test_all_tables FOR ALL TABLES;

DROP PUBLICATION test_all_tables;

create table test(id int,name varchar(20));

insert into test values(generate_series(100000,500000),'wjf');

//删除订阅

alter subscription test disable;

alter subscription test set (slot_name =none);

DROP SUBSCRIPTION test;

====启动订阅服务,另一个pg

DROP SUBSCRIPTION test;

SELECT * FROM pg_catalog.pg_publication;

DROP SUBSCRIPTION sbtest;

SELECT * FROM pg_subscription;

CREATE SUBSCRIPTION test CONNECTION 'host=localhost port=5432 dbname=postgres user=aaron password=admin' PUBLICATION test_all_tables;

CREATE SUBSCRIPTION sbtest CONNECTION 'host=localhost port=5432 dbname=postgres user=aaron password=admin'

PUBLICATION test_all_tables with (create_slot = false,slot_name = test);

相关推荐
小陈工1 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
科技小花6 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸6 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain6 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希6 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神6 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员7 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java7 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿7 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴7 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存