2015-10-05 57 views
0

发生了最奇怪的事情。我们有一个mongodb实例,将日志和日志记录在由ebs支持的单个amazon ec2上运行的独立硬盘上。今天早上服务器意外关闭,当我看着它时,我注意到mongo没有在启动时启动。MongoDB意外关机和数据丢失

我手动使用命令

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文件,尽管存在旧文件。这里发生了什么以及如何恢复数据?

回答

0

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

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

  1. 检查是否正在使用相同的MongoDB配置,使用前 服务器下楼
  2. 检查您的EBS卷装的预期。您可以使用mount选项来确认 path/data/db指向正确的EBS卷。

而且可以肯定的是,如果实例使用临时驱动器,那么当实例关闭时数据将会丢失。有时候人们会将短暂的驱动器与弹性块存储混淆,其中持久存在。