postgresql 先创建唯一主键 再分区_记一次表改成分区表导致CPU 100%问题

为了解决磁盘空间压力,将一个上亿条记录的大表改造成日期分区表。但在创建分区并切换后,出现大量慢SQL导致CPU飙升。原因是查询未使用分区键,造成全表扫描。紧急回滚并修复,通过kill慢SQL恢复业务,并提醒未来更改表结构时务必检查所有操作语句。
摘要由CSDN通过智能技术生成

ff7c5fa9c8d1a55311bcb1ff7bb18ae6.png

背景

为了方便归档并清理数据,释放磁盘空间压力,将一张数据量很大的表(上亿)更改为根据日期分区表

过程

  • 让开发排查代码中使用到这个表的语句,是否都使用到了分区键
  • 保证数据写入分区键时候不为null
  • 创建分区表并迁移数据
  • 切换表

问题表现

  • 短时间内出现大量的慢SQL堆积,`show processlist`查看到都是这个表的,都处于 sending data状态
  • 语句是根据某个常量条件count一下,源表上 vb 这个字段是唯一索引,语句如下
select count(*) from tb_test where vb = 'aaabbbccc' and vc != '0'
  • 由于大量的慢SQL积压,导致并发升高,CPU 到 100%

修正回滚

出问题了,先不管那么多,先把表切回去,恢复业务,再进行排查问题

kill掉符合条件的慢SQL

询问下开发,造成问题的这部分的select慢SQL是否可以kill,还好只是select

    • 0
      点赞
    • 0
      收藏
      觉得还不错? 一键收藏
    • 0
      评论
    评论
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值