日志堆积之Replication Slot-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

日志堆积之Replication Slot

用户为了进行逻辑同步复制,在使用 DTS 的时候都会去打开对应的replication slot。checkpoint删除xlog日志的时候,都会保留大于mini replication slots lsn的xlog日志,所以会导致日志积累。

使用如下 SQL 查看 replication slot 的消费情况:

SELECT
      pg_xlog_location_diff(
        l.current_location,
        s.restart_lsn
      ) /(1024 * 1024) AS logical_rep_latency_MB
    FROM
      pg_replication_slots s,
      pg_current_xlog_location() l(current_location)
    ORDER BY
      logical_rep_latency_MB DESC

检查是否存在replication_slot的方法如下:

select * from pg_replication_slots;

以上查询结果中,如果 restart_lsn 比较旧,主库就会去保留在这之后的xlog 日志文件。

当出现这种情况,只需要删除 replication slot,然后 checkpoint,验证是否能否正常清理。如果正常清理,则是这个原因,否则还需要探查其他的原因。

删除 logical_slot 的方法如下:

select pg_drop_replication_slot('slot1');

展开
收起
rds4pg 2018-09-18 19:39:05 4424 0
1 条回答
写回答
取消 提交回答
  • 吃奥利奥吗
    先为大家带来一点福利,领取千元大礼包,阿里云代金券领取地址:https://promotion.aliyun.com/ntms/yunparter/invite.html?userCode=qyowv5ea

    同问

    2019-07-17 23:05:45
    赞同 展开评论 打赏
问答排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载