我已经在 mongodb google group中提出了这个问题,但这里没有任何回复。
我们有一个单节点 mongo(版本 2.0.1)实例。即使在每天归档之后,我们的磁盘空间也用完了,因为 mongo 不会将空间返回给操作系统并尝试自己使用它。目前,我们的设置变得非常稀疏,大约 50% 的空间处于空闲状态。您可以看到数据 + 索引大小约为 1170 GB,而存储大小约为 2158 GB,文件大小约为 2368 GB。
db.stats()
{
"db" : "default",
"collections" : 106,
"objects" : 553988389,
"avgObjSize" : 2094.1392962010254,
"dataSize" : NumberLong("1160128855044"),
"storageSize" : NumberLong("2315777236208"),
"numExtents" : 1487,
"indexes" : 107,
"indexSize" : 97914435136,
"fileSize" : NumberLong("2543459500032"),
"nsSizeMB" : 16,
"ok" : 1
}
我们想要回收空间,因为这不是一个关键任务系统(它就像一个原木倾倒场)可以维持停机时间。我们不想花在创建副本集上,我们也在物理数据中心,因此不希望仅附加额外的磁盘来修复数据库。
我想了解:-
- 修复数据库需要多少可用磁盘空间 - 修复数据库
后我们希望恢复多少空间 - 修复数据库
需要多长时间。
- 如果修复数据库继续运行,那么杀死它并重新启动数据库是否安全。
我们的大部分数据位于单个集合中,因此紧凑集合是否比修复数据库更好。