gpt4 book ai didi

mongodb - 为什么我的 mongo local db oplog 巨大

转载 作者:可可西里 更新时间:2023-11-01 09:37:01 26 4
gpt4 key购买 nike

感谢对此的任何见解,我有 2 个问题:

1) 弄清楚为什么我的本地数据库 oplog 庞大且不断增长
2) 安全删除(或重置)我的 local.oplog 以释放 18 GB 的浪费空间

场景:我一直在像这样的生产数据快照上本地运行 mongod:

   mongod --dbpath /temp/MongoDumps/mongodata-2013-06-05_1205-snap/data

所以我注意到奇怪的是我的本地数据库很大

> show dbs
local 18.0693359375GB
prod-snapshot 7.9501953125GB

这似乎是由于巨大的本地数据库 oplog(即使它是一个上限集合)

db.oplog.rs.stats()
{
"ns" : "local.oplog.rs",
"count" : 25319382,
"size" : 10440151664,
"avgObjSize" : 412.33832895289464,
"storageSize" : 18634489728,
"numExtents" : 9,
"nindexes" : 0,
"lastExtentSize" : 1463074816,
"paddingFactor" : 1,
"systemFlags" : 0,
"userFlags" : 0,
"totalIndexSize" : 0,
"indexSizes" : {

},
"capped" : true,
"max" : NumberLong("9223372036854775807"),
"ok" : 1
}

尽管我的本地没有设置任何副本集,但我的本地数据库似乎继承了我的生产副本集配置(也许它是通过快照继承的???)

rs.config()
{
"_id" : "mongocluster1",
"version" : 38042,
"members" : [
{
"_id" : 4,
"host" : "mongolive-01D.mcluster-01:27017",
"tags" : {
"app" : "backend"
}
},
{
"_id" : 5,
"host" : "mongolive-01C.mcluster-01:27017"
},
{
"_id" : 11,
"host" : "mongoarbiter-01C.mcluster-01:27017",
"arbiterOnly" : true
},
{
"_id" : 7,
"host" : "mongoremote-01Z.mcluster-01:27017",
"priority" : 0,
"hidden" : true
},
{
"_id" : 21,
"host" : "mongodelayed-01D.mcluster-01:27017",
"priority" : 0,
"slaveDelay" : 3600,
"hidden" : true
}
]
}

不确定是否相关但也看到了这个:

> rs.status()
{ "ok" : 0, "errmsg" : "not running with --replSet" }

当我启动服务器时,我收到一个 replicaSet 警告:

    MongoDB shell version: 2.4.1
connecting to: test
Server has startup warnings:

** WARNING: soft rlimits too low. Number of files is 256, should be at least 1000

** WARNING: mongod started without --replSet yet 1 documents are present in local.system.replset
** Restart with --replSet unless you are doing maintenance and no other clients are connected.
** The TTL collection monitor will not start because of this.

最佳答案

您捕获了生产节点数据目录的快照,因此您获得了它的精确数据库配置。

这包括它的“本地”数据库。本地数据库包括(除其他外)副本集配置和操作日志。

因为您打算在独立模式下运行您的 mongod,您可以简单地删除 local 数据库而不会产生不良影响。使用 dropDatabase() 命令。这将删除数据库,操作系统将回收空间。

关于mongodb - 为什么我的 mongo local db oplog 巨大,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17247128/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com