tencent cloud

云数据库 MongoDB

动态与公告
产品动态
公告
新手指引
产品简介
产品概述
产品优势
应用场景
集群架构
产品规格
产品功能
地域和可用区
名词解释
购买指南
计费概述
产品定价
计费公式
欠费说明
备份空间计费
变配计费说明
快速入门
快速创建实例
连接 MongoDB 实例
读写数据库
操作指南
访问管理
管理实例
节点管理
版本升级
网络配置
系统监控
备份与回档
数据库审计
数据安全
SSL 认证
日志管理
数据库管理
多可用区部署
只读灾备
参数配置
回收站
任务管理
诊断优化
数据迁移指引
实践教程
索引优化解决读写性能瓶颈
分片集群 Mongos 负载不均解析及应对方案
分片集群使用注意事项
MongoDB 协议实例读写示例
基于 CVM 连接 MongoDB 进行数据导入导出的方法
3.6版本实例反复创建和删除同名数据库时报错怎么办
无法连接 MongoDB 解决方法
删减分片任务:进度确认与异常排查指南
性能调优
运维开发指南
开发规范
3.2版本分片集群命令支持情况
3.6版本命令支持情况
开发运维
故障处理
慢查询增多
连接数超限
API 文档
History
Introduction
API Category
Making API Requests
Instance APIs
Backup APIs
Account APIs
Other APIs
Task APIs
Introduction
Data Types
Error Codes
SDK 参考
Shell连接示例
PHP 连接示例
Node.js连接示例
Java 连接示例
Python连接示例
Python 读写示例
Go 连接示例
PHP 重连示例
产品性能
测试环境
测试方法
测试结果
常见问题
费用相关问题
功能特性问题
分片集群问题
实例相关问题
回档备份问题
连接相关问题
数据迁移问题
其他常见问题
相关协议
服务等级协议
Terms of Service
词汇表
联系我们

恢复至自建数据库

PDF
聚焦模式
字号
最后更新时间: 2024-01-12 09:44:33

物理备份恢复至自建数据库

副本集实例只有一份数据,分片集群每个片会有一份数据,请您根据自身业务需要来选择性恢复数据。下文介绍的是单份数据的恢复方法。

恢复数据至单节点

1. 将数据拷贝至自建数据库的数据目录(需保证该目录为空),例如目录为 /data/27017/。
cp -r * /data/27017/
2. 重启 mongod 并校验数据。命令示例如下:
./mongod --dbpath /data/27017 --port 27017 --logpath /var/log/mongodb/27017.log --fork

恢复数据至副本集

物理备份默认带有原实例的配置,因此需移除原有配置,否则可能导致数据无法访问。
1. 将数据恢复至单节点自建数据库,然后以副本集方式重启该节点。重启命令示例如下:
./mongod --replSet mymongo --dbpath /data/27017 --port 27017 --logpath /var/log/mongodb/27017.log --fork
2. 登录该节点清除原实例的副本集配置,命令如下:
rs.slaveOk()
use local
db.system.replset.remove({})
3. 重启该节点,将新节点加入副本集进行初始化并校验数据,加入副本集的节点需已启动且无数据。命令示例如下:
rs.initiate({"_id":"mymongo","members":[{"_id":0,"host":"127.0.0.1:27017"},{"_id":1, "host":"127.0.0.1:27018"},{"_id":2, "host":"127.0.0.1:27019"}]})
rs.initiate() 命令介绍请参见 MongoDB 官网文档
说明:
不支持恢复数据至分片集群,由于分片集群物理备份的路由缺失,所以即使将每个分片的数据恢复至自建副本集(分片集群的每一个片),mongos 也只能读取到主分片的数据。

逻辑备份恢复至自建数据库

为不影响数据恢复到自建数据库之后的验证,需确保自建数据库为空。
对于3.6版本,需手动删除 config 目录再依次使用 mongorestore 命令恢复每个片的数据。如下图所示:



对于3.2版本,需手动将单个库表的文件合并后才能恢复数据。合并文件操作示例如下: 数据库ycsb目录下有一个表格为c_10,该表格涉及的数据文件为c_10.bson.gz.chunk-64c_10.bson.gz.chunk-127,则合并命令为cat c_10.bson.gz.chunk-* > ./c_10.bson.gz
说明:
3.2版本部分场景下时会出现 chunk 区分。
使用 mongorestore 命令恢复数据,-h 参数指定自建数据库地址,--dir 参数指定数据文件所在目录,必须指定 --gzip 参数来解压备份文件。命令如下:
./mongorestore --gzip --drop -h127.0.0.1:27017 --dir ./1544517027220146694


帮助和支持

本页内容是否解决了您的问题?

填写满意度调查问卷,共创更好文档体验。

文档反馈