文章目录
背景介绍
客户有一个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导出数据备用。