5.mongodb误删除文件,无法启动

1.场景 

mongodb数据目录下误删除个别数据文件,导致mongodb无法启动。

2.修复方法

(1)注释fork;
vi mongod.conf 
processManagement:
#    fork: true

--执行修复命令
--如下命令未修复成功。
--/mysqlbackup/mongodb/bin/mongod --dbpath /mysqlbackup/mongosc --port 27018  --oplogSize 512  \
----bind_ip 0.0.0.0 --logpath /var/log/mongodb/mongodb.log \
----logappend --journal --directoryperdb --profile=1 --repair



(2)修复数据库。
/mysqlbackup/mongodb/bin/mongod -f /mysqlbackup/mongodb/mongod.conf  --repair & 

(3)观察日志输出。
tail -100f /var/log/mongodb/mongod.conf 
2024-01-04T17:57:48.041+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 86400
2024-01-04T17:57:48.465+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 86500
2024-01-04T17:57:48.928+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 86600
2024-01-04T17:57:49.349+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 86700
2024-01-04T17:57:49.826+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 86800
2024-01-04T17:57:50.282+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 86900
2024-01-04T17:57:50.755+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87000
2024-01-04T17:57:51.239+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87100
2024-01-04T17:57:51.750+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87200
2024-01-04T17:57:52.232+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87300
2024-01-04T17:57:52.727+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87400
2024-01-04T17:57:53.205+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87500
2024-01-04T17:57:53.695+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87600
2024-01-04T17:57:54.222+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87700
2024-01-04T17:57:54.742+0800 I  STORAGE  [initandlisten] WiredTiger progress WT_SESSION.verify 87800
..................................................................................................
2024-01-04T20:22:52.898+0800 W  STORAGE  [initandlisten] WARNING: Repair may have modified replicated data. This node will no longer be able to join a replica set without a full re-sync
2024-01-04T20:22:52.901+0800 I  STORAGE  [initandlisten] Flow Control is enabled on this deployment.
2024-01-04T20:22:52.901+0800 I  STORAGE  [initandlisten] finished checking dbs  (修复完成)
2024-01-04T20:22:52.901+0800 I  -        [initandlisten] Stopping further Flow Control ticket acquisitions.
2024-01-04T20:22:52.901+0800 I  STORAGE  [initandlisten] Deregistering all the collections
2024-01-04T20:22:52.901+0800 I  STORAGE  [WTOplogJournalThread] Oplog journal thread loop shutting down
2024-01-04T20:22:52.901+0800 I  STORAGE  [initandlisten] Timestamp monitor shutting down
2024-01-04T20:22:52.902+0800 I  STORAGE  [initandlisten] WiredTigerKVEngine shutting down
2024-01-04T20:22:52.905+0800 I  STORAGE  [initandlisten] Shutting down session sweeper thread
2024-01-04T20:22:52.905+0800 I  STORAGE  [initandlisten] Finished shutting down session sweeper thread
2024-01-04T20:22:52.905+0800 I  STORAGE  [initandlisten] Shutting down journal flusher thread
2024-01-04T20:22:52.948+0800 I  STORAGE  [initandlisten] Finished shutting down journal flusher thread
2024-01-04T20:22:52.948+0800 I  STORAGE  [initandlisten] Shutting down checkpoint thread
2024-01-04T20:22:52.948+0800 I  STORAGE  [initandlisten] Finished shutting down checkpoint thread
2024-01-04T20:22:53.056+0800 I  STORAGE  [initandlisten] shutdown: removing fs lock...
2024-01-04T20:22:53.057+0800 I  CONTROL  [initandlisten] now exiting
2024-01-04T20:22:53.057+0800 I  CONTROL  [initandlisten] shutting down with code:0

(4)修复结束后启动数据库
--启动
/mysqlbackup/mongodb/bin/mongod   -f /mysqlbackup/mongodb/mongod.conf &

--登录:
/mysqlbackup/mongodb/bin/mongo --host 10.1.1.1 --port=27018

>use admin 
>db.auth("admin","admin");   --密码认证登录。
(5)查看数据库和集合
> show dbs;
admin         0.000GB
config        0.000GB
edocuments  947.649GB
local         0.000GB
> use edocuments;
switched to db edocuments
> show collections;
base_interface_record
base_interface_record_20231024
car_pics_interface_record

我的参数文件如下:

vi mongod.conf 
systemLog:
    destination: file
    logAppend: true
    path: /var/log/mongodb/mongodb.log
storage:
    dbPath: /mysqlbackup/mongosc
    journal:
        enabled: true
processManagement:
#    fork: true
    pidFilePath: /mysqlbackup/mongosc/mongodb.pid
    timeZoneInfo: /usr/share/zoneinfo
net:
    port: 27018
    bindIp: 0.0.0.0

security:
    keyFile: "/mysqlbackup/mongosc/mongodb_keyfile"
    clusterAuthMode: "keyFile"
    authorization: "enabled"

 

3.总结

由此可见,即使mongodb的个别数据文件 collection-13-7183433419409953098.wt 文件被误删除后,其他正常的文件,还是可以通过repair命令进行修复。只不过丢失的数据就无法找回了。所以做好备份是非常重要的。

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
项目突然跑不起来报这个错 Exception in monitor thread while connecting to server 10.18.21.79:27117 com.mongodb.MongoSocketReadException: Exception receiving message at com.mongodb.connection.InternalStreamConnection.translateReadException(InternalStreamConnection.java:536) at com.mongodb.connection.InternalStreamConnection.receiveMessage(InternalStreamConnection.java:421) at com.mongodb.connection.InternalStreamConnection.receiveCommandMessageResponse(InternalStreamConnection.java:290) at com.mongodb.connection.InternalStreamConnection.sendAndReceive(InternalStreamConnection.java:255) at com.mongodb.connection.CommandHelper.sendAndReceive(CommandHelper.java:84) at com.mongodb.connection.CommandHelper.executeCommand(CommandHelper.java:34) at com.mongodb.connection.InternalStreamConnectionInitializer.initializeConnectionDescription(InternalStreamConnectionInitializer.java:91) at com.mongodb.connection.InternalStreamConnectionInitializer.initialize(InternalStreamConnectionInitializer.java:51) at com.mongodb.connection.InternalStreamConnection.open(InternalStreamConnection.java:127) at com.mongodb.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:114) at java.lang.Thread.run(Thread.java:748) Caused by: java.net.SocketException: Connection reset at java.net.SocketInputStream.read(SocketInputStream.java:210) at java.net.SocketInputStream.read(SocketInputStream.java:141) at com.mongodb.connection.SocketStream.read(SocketStream.java:84) at com.mongodb.connection.InternalStreamConnection.receiveResponseBuffers(InternalStreamConnection.java:547) at com.mongodb.connection.InternalStreamConnection.receiveMessage(InternalStreamConnection.java:418)
06-09

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值