MongoDB意外关机和数据丢失

时间:2015-10-05 17:13:39

标签: mongodb amazon-ec2 data-loss

最奇怪的事情发生了。我们有一个mongodb实例,日志和日志都在单独的硬盘驱动器上运行在由ebs支持的单个亚马逊ec2上。今天早上服务器意外关机,当我看到它时,我注意到mongo没有在启动时启动。

我使用命令

手动启动mongo
sudo mongod --fork --logpath /var/log/mongodb.log

它运行正常但是当我查看数据库时,我们所有的数据都丢失了。我尝试退出--repair选项,但它没有做任何事情。这是最初的mongod的日志:

2015-10-05T16:39:17.881+0000 [initandlisten] MongoDB starting : 

pid=2757 port=27017 dbpath=/data/db 64-bit host=ip-172-31-59-166
2015-10-05T16:39:17.882+0000 [initandlisten] db version v2.6.8
2015-10-05T16:39:17.882+0000 [initandlisten] git version: 3abc04d6d4f71de00b57378e3277def8fd7a6700
2015-10-05T16:39:17.882+0000 [initandlisten] build info: Linux build5.nj1.10gen.cc 2.6.32-431.3.1.el6.x86_64 #1 SMP Fri Jan 3 21:39:27 UTC 2014 x86_64 BOOST_LIB_VERSION=1_49
2015-10-05T16:39:17.882+0000 [initandlisten] allocator: tcmalloc
2015-10-05T16:39:17.882+0000 [initandlisten] options: { processManagement: { fork: true }, systemLog: { destination: "file", path: "/var/log/mongodb.log" } }
2015-10-05T16:39:17.890+0000 [initandlisten] journal dir=/data/db/journal
2015-10-05T16:39:17.893+0000 [initandlisten] recover : no journal files present, no recovery needed
2015-10-05T16:39:17.893+0000 [initandlisten] preallocating a journal file /data/db/journal/prealloc.1
2015-10-05T16:39:28.081+0000 [initandlisten] preallocating a journal file /data/db/journal/prealloc.2
2015-10-05T16:39:40.496+0000 [initandlisten] allocating new ns file /data/db/local.ns, filling with zeroes...
2015-10-05T16:39:40.654+0000 [FileAllocator] allocating new datafile /data/db/local.0, filling with zeroes...
2015-10-05T16:39:40.654+0000 [FileAllocator] creating directory /data/db/_tmp
2015-10-05T16:39:40.659+0000 [FileAllocator] done allocating datafile /data/db/local.0, size: 64MB,  took 0.002 secs
2015-10-05T16:39:40.664+0000 [initandlisten] build index on: local.startup_log properties: { v: 1, key: { _id: 1 }, name: "_id_", ns: "local.startup_log" }
2015-10-05T16:39:40.664+0000 [initandlisten]     added index to empty collection
2015-10-05T16:39:40.665+0000 [initandlisten] command local.$cmd command: create { create: "startup_log", size: 10485760, capped: true } ntoreturn:1 keyUpdates:0 numYields:0  reslen:37 169ms
2015-10-05T16:39:40.669+0000 [initandlisten] waiting for connections on port 27017

看起来MongoDB初始启动没有问题。但它也表示它正在创建新的ns文件,尽管存在旧文件。这里发生了什么以及如何恢复数据?

1 个答案:

答案 0 :(得分:0)

没有任何迹象表明有任何损坏。日志表明此实例是在空卷上启动的。

除了logPath之外,您的MongoDB进程正在使用默认参数启动。因此,它将使用/ data / db作为数据目录的位置。根据您对问题的初始描述,您可能一直在运行单独的日志和数据目录EBS挂载,即您使用的MongoDB配置--dbpath。

  1. 检查您使用的是与使用的相同的MongoDB配置 在服务器发生故障之前
  2. 检查您的EBS卷是否已安装。您可以使用mount选项确认 path / data / db指向正确的EBS卷。
  3. 并且只是为了确定...如果实例使用了临时驱动器,则实例关闭时数据将丢失。有时人们会将短暂的驱动器与弹性块存储混淆,后者 持久存在。