gpt4 book ai didi

MongoDB 修复命令失败

转载 作者:可可西里 更新时间:2023-11-01 10:01:19 24 4
gpt4 key购买 nike

之前我的磁盘空间不足,mongodb 停止工作。然后我增加了磁盘大小,但 mongodb 没有开始工作。

虽然我启用了日记功能,但我执行了以下命令
sudo -u mongodb mongod --dbpath/var/lib/mongodb/--repair

但是这个修复命令出现异常,停止修复退出。

    Fri Nov 30 13:29:36 [initandlisten] build index bd_production.news { _id: 1 }

Fri Nov 30 13:29:36 [initandlisten] fastBuildIndex dupsToDrop:0

Fri Nov 30 13:29:36 [initandlisten] build index done. scanned 2549 total
records. 0.008 secs

Fri Nov 30 13:29:36 [initandlisten] bd_production.change_sets
Assertion failure isOk() src/mongo/db/pdfile.h 360

0x879d86a 0x85a9835 0x85e441e 0x84caa02 0x84c7d19 0x8229b5a 0x822bfd8
0x875bd51 0x875f0c7 0x8760df4 0x83e6523 0x83b6c3b 0x8753b07 0x83b92bf
0x8827ab7 0x882a53b 0x882d4bf 0x882d691 0x85ed280 0x81719dc

mongod(_ZN5mongo15printStackTraceERSo+0x2a) [0x879d86a]

mongod(_ZN5mongo10logContextEPKc+0xa5) [0x85a9835]
...
...
...
... some error msg

Fri Nov 30 13:29:36 [initandlisten] assertion 0 assertion
src/mongo/db/pdfile.h:360 ns:bd_production.change_sets
query:{}

Fri Nov 30 13:29:36 [initandlisten] problem detected during query over
bd_production.change_sets : { $err: "assertion
src/mongo/db/pdfile.h:360" }

Fri Nov 30 13:29:36 [initandlisten] query
bd_production.change_sets ntoreturn:0 keyUpdates:0 exception:
assertion src/mongo/db/pdfile.h:360 reslen:71 197ms

Fri Nov 30 13:29:36 [initandlisten] exception in initAndListen: 13106
nextSafe(): { $err: "assertion src/mongo/db/pdfile.h:360" }, terminating

Fri Nov 30 13:29:36 dbexit:
...
...

新闻集合已成功修复,但 'change_set' 未成功修复。

我如何修复那个特定的集合(变更集)或数据库?

更新:当我使用 --repair 为那个 change_set 集合运行 mongodump 时,我收到以下错误消息:

Tue Dec  4 10:45:21 [tools]         backwards extent pass
Tue Dec 4 10:45:21 [tools] extent loc: 5:1181e000
Tue Dec 4 10:45:21 [FileAllocator] allocating new datafile /home/suvankar/dd/bd_production.5, filling with zeroes...
Tue Dec 4 10:45:21 [FileAllocator] creating directory /home/suvankar/dd/_tmp
Tue Dec 4 10:45:21 [FileAllocator] done allocating datafile /home/suvankar/dd/bd_production.5, size: 511MB, took 0.042 secs
Tue Dec 4 10:45:21 [tools] warning: Extent not ok magic: 0 going to try to continue
Tue Dec 4 10:45:21 [tools] length:0
Tue Dec 4 10:45:21 [tools] ERROR: offset is 0 for record which should be impossible
Tue Dec 4 10:45:21 [tools] wrote 1 documents
Tue Dec 4 10:45:21 [tools] extent loc: 0:0
Tue Dec 4 10:45:21 [tools] ERROR: invalid extent ofs: 0
Tue Dec 4 10:45:21 [tools] 5 objects
Tue Dec 4 10:45:21 dbexit:
Tue Dec 4 10:45:21 [tools] shutdown: going to close listening sockets...
Tue Dec 4 10:45:21 [tools] shutdown: going to flush diaglog...
Tue Dec 4 10:45:21 [tools] shutdown: going to close sockets...
Tue Dec 4 10:45:21 [tools] shutdown: waiting for fs preallocator...
Tue Dec 4 10:45:21 [tools] shutdown: lock for final commit...

最佳答案

如果 mongod with repair 没有执行此操作,那么它就会遇到无法修复或解决的损坏级别,因为它无法拥有一组有效且正确的数据库文件启动。

您可以运行 mongodump with repair ,这在试图绕过损坏方面更具侵略性,并且不会启动 mongod 实例(因此不需要文件正确才能继续)。

mongodump --repair --dbpath /var/lib/mongodb/ <other options here>

但请注意,由于它试图绕过损坏的方式,您最终可能会得到一个文档的多个副本。怎么配mongorestore工作 这不是问题,但根据损坏的程度,您最终可能会得到比您预期的大得多的转储文件。在一个非常极端的案例中,我曾经看到产生了 10 倍的数据,尽管那是异常(exception)而不是规则。

一旦您将所有内容都转储到您满意的程度,请启动 mongod clean 并重新导入以恢复到良好状态。

关于MongoDB 修复命令失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13680098/

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