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

PostgreSQL逻辑复制-删除订阅报错

瀚高PG实验室 2021-04-16
1030

文章目录

删除订阅报错

复制槽管理说明


删除订阅报错

删除订阅报错

或者

当删除与远程主机(正常状态)上的复制槽相关联的订阅时,DROP SUBSCRIPTION 将连接到远程主机,并尝试删除该复制槽,作为其操作的一部分。这是必要的, 以便释放远程主机上为订阅分配的资源。如果失败,因为远程主机不可访问, 或者因为远程复制槽不能被删除,或者复制槽不存在或从不存在, 则DROP SUBSCRIPTION命令将失败。要在这种情况下继续, 请执行ALTER SUBSCRIPTION … SET (slot_name = NONE) 来解除复制槽与订阅的关联。之后,DROP SUBSCRIPTION 将不再尝试对远程主机执行任何操作。请注意,如果远程复制槽仍然存在, 则应手动删除该插槽;否则将继续保留WAL,最终可能导致磁盘空间不足解除复制槽与订阅的关联,然后删除。

复制槽管理说明

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

在删除一个订阅是,远程主机不可达。在这种情况下,可以在尝试删除该订阅之前,使用ALTER SUBSCRIPTION将复制槽解除关联。如果远程数据库实例不再存在,那么不需要进一步的行动。不过,如果远程数据库实例只是不可达,那么复制槽应该被手动删除。否则它将会继续保留WAL并且最终可能会导致磁盘被填满。这种情况应该要仔细地研究。


ref Replication Slot Management
ref 复制槽管理





最后修改时间:2021-04-16 13:34:40
文章转载自瀚高PG实验室,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论