mongodb 大表建索引CPU跑满了怎么办【已解决】

表长大了再建索引,或是删除索引再建索引,大概率是慢查询打满的cup,再加上建索引操作的助攻,mongo可能就直接跪了。如果线上已经出了问题不可用了,万分紧急的情况下,使用此方法

  1. 查询正在建索引的op
db.currentOp(
    {
      $or: [
        { op: "command", "query.createIndexes": { $exists: true } },
        { op: "none", ns: /\.system\.indexes\b/ }
      ]
    }
)
  1. 杀掉对应的op
db.killOp(opid)
  1. 如果找不到opid也没关系,改名可以逼死建索引的操作,步骤3-4才是关键
db.current_collection.renameCollection("current_collection_bak")

改完名后需要等一下,原collection建索引的操作才会死,这个时候可以建好改名后collection的索引,再rename回去。因为改了名,程序查不到原collection,没有了慢查询,CPU会恢复正常。

db.current_collection_bak.createIndex({"field":1})
  1. 如果有新的数据插入原collection,在改回原名时可能会出现原collection已存在的错误,这时候需要一波骚操作,先在编辑器上写好命令,一起粘到终端执行
db.current_collection.drop()
db.current_collection_bak.renameCollection("current_collection")

第一条命令可以选择再改成其他名方便后续回补数据或是直接删除,手速快一点哈


大表建立索引建议停服操作,改名这种操作肯定会影响业务,别等到服务不可用的时候再操作!!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值