MongoDB dropdatabase 后,数据能恢复么?
最近好几个社区用户咨询,错误的执行了 dropDatabse 把数据库误删除了(或 dropCollection 误删集合),有什么方法能恢复数据?本文主要介绍几种可能有效的恢复方案。
方案1:通过备份集恢复
如果对 MongoDB 做了全量备份 + 增量备份,那么可以通过备份集及来恢复数据。备份可以是多种形式,比如
- 通过 mongodump 等工具,对数据库产生的逻辑备份
- 拷贝 dbpath 目录产生的物理备份
- 文件系统、卷管理等产生的快照等
从这里其实也可以看出一个问题,就是「部署了多节点的复制集,为什么还需要做数据备份?」;遇到误删数据库这种问题,dropDatabase 命令也会同步到所有的备节点,导致所有节点的数据都被删除。
方案2:通过 oplog 恢复
如果部署的是 MongoDB 复制集,这时还有一线希望,可以通过 oplog 来