其他分享
首页 > 其他分享> > 逻辑复制-删除订阅报错

逻辑复制-删除订阅报错

作者:互联网

作者:瀚高PG实验室(Highgo PG Lab)-Chrisx

文章目录


删除订阅报错

删除订阅报错

test=# drop subscription test_slot_sub ;ERROR:  could not connect to publisher when attempting to drop the replication slot "test_slot_sub"DETAIL:  The error was: could not connect to server: Connection refused        Is the server running on host "127.0.0.1" and accepting
        TCP/IP connections on port 5433?
HINT:  Use ALTER SUBSCRIPTION ... SET (slot_name = NONE) to disassociate the subscription from the slot.test=#

或者

test=# drop subscription test_slot_sub ;ERROR:  could not drop the replication slot "test_slot_sub" on publisher
DETAIL:  The error was: ERROR:  replication slot "test_slot_sub" does not exist
test=#

解除复制槽与订阅的关联,然后删除。

alter subscription test_slot_sub disable;ALTER SUBSCRIPTION test_slot_sub SET (slot_name = NONE);drop subscription test_slot_sub ;

复制槽管理说明

每一个(活跃的)订阅会从远(发布)端上的一个复制槽接收更改。通常,远程复制槽是在使用CREATE SUBSCRIPTION创建订阅是自动创建的,并且在使用DROP SUBSCRIPTION删除订阅时,复制槽也会自动被删除。不过,在一些情况下,有必要单独操纵订阅以及其底层的复制槽。如下场景:

在删除一个订阅是,远程主机不可达。在这种情况下,可以在尝试删除该订阅之前,使用ALTER SUBSCRIPTION将复制槽解除关联。如果远程数据库实例不再存在,那么不需要进一步的行动。

不过,如果远程数据库实例只是不可达,那么复制槽应该被手动删除。否则它将会继续保留WAL并且最终可能会导致磁盘被填满。这种情况应该要仔细地研究。

标签:slot,订阅,删除,复制,报错,test,SUBSCRIPTION
来源: https://blog.51cto.com/13646489/2681017