从mongodb副本集的某一个节点数据用另一个mongodb实例来启动

背景介绍

客户有一个mongodb副本集使用statefulset部署在k8s集群中,使用hostPath将数据持久化到node上。突然有一天k8s集群因为证书问题无法访问,导致mongodb集群也直接“失联”。经过处理,无法恢复K8s集群,所以准备重建k8s。因为一些原因以前数据库备份文件无法使用。所以需要从现有的环境中拷贝数据使用。

1、准备源数据

将其中一个mongo的持久化数据拷贝到其他服务器上。

2、准备一个环境

最好使用centos7系统的服务器,因为我发现ubuntu系统当使用二进制启动时会提示有一个库文件丢失;

2.1 下载mongodb二进制包

官网,最好下载原集群对应的版本。否则会有奇奇怪怪的错误。本次使用4.2.17版本

2.2 解压过后,准备配置文件:

cat /etc/mongodb.conf
port = 27001
dbpath = /data/mongodb/mongodb_data  #/data/mongodb提前创建,mongodb_data暂时不创建
logpath = /data/mongodb/logs/mongodb.log #/data/mongodb/logs需提前创建,注意权限
logappend = true
fork = true
journal = true
bind_ip = 0.0.0.0

2.3 将客户文件放入新实例数据目录

注意,在放入数据目录前先不要启动mongodb。
将客户数据放入/data/mongodb/并修改名字为mongdb_data

2.4 启动数据库

mongod -f /etc/mongodb.conf

此时会出现两种情况:

2.4.1 正常启动,且不会异常退出

此时即可正常使用,使用Mongodump导出数据。

2.4.2 正常启动,但是不到一分钟就自己退出

解决办法:

  • 删除dbpath路径下的*.lock文件 (或者移动到其他目录下)
  • 修复数据(很耗时间) mongod --repair --dbpath=/data/mongodb/mongodb_data,等修复完成过后,再次启动。我有18G数据,差不多花费了20分钟。

此时可以正常启动数据库,然后mongodump导出数据备用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值