mongodb-数据备份和恢复

mongodb-database-tools

mongodb-database-tools是MongoDB官方提供的一组命令行工具,用于执行各种与MongoDB数据库相关的操作,包括备份、恢复、导入、导出、查询和转换数据等。这些工具可帮助开发人员和管理员轻松地管理MongoDB数据库。

以下是一些常用的mongodb-database-tools工具:

  • mongodump: 用于备份MongoDB数据库。
  • mongorestore: 用于从备份文件中恢复MongoDB数据库。
  • mongoimport: 用于将数据导入到MongoDB数据库中。
  • mongoexport: 用于将数据从MongoDB数据库中导出。
  • mongostat: 用于监视MongoDB服务器的状态和性能。
  • mongooplog: 用于监视MongoDB服务器上的操作日志。
  • mongotop: 用于监视MongoDB数据库中的读/写操作。

要使用这些工具,需要在计算机上安装MongoDB数据库,并确保mongodb-database-tools已安装和配置。工具的使用方法可以通过运行--help-h选项来获取帮助。例如,要查看mongodump命令的帮助,可以运行以下命令:

shell 复制代码
mongodump --help

下载

  1. 去官网下载:Download MongoDB Command Line Database Tools | MongoDB

安装

将文件上传到服务器,然后解压缩

shell 复制代码
tar -zxvf mongodb-database-tools-*-100.9.5.tgz

将命令配置到 bin中方便使用

shell 复制代码
mv ./mongodb-database-tools-rhel70-x86_64-100.9.5/bin/* /usr/local/bin/

帮助

shell 复制代码
mongodump --help

这将显示mongodump命令的用法和选项列表。

数据备份

shell 复制代码
mongodump --host 127.0.0.1 \
--port 20017 \
--username root\
--password 111111\
--authenticationDatabase admin \
--authenticationMechanism SCRAM-SHA-1 \
--db ZHIYUN_PROD_MONGO \
--collection DATA_COLLECT \
--query '{"date_field": {"$lt": {"$date": "2022-12-31T00:00:00Z"}}}' \
--out back/ \
--gzip

!命令说明\]- --host host --port 端口 --username 用户名 --password 密码 --authenticationDatabase --authenticationMechanism --db 库 --collection 集合 --query 导出某个时间段 --out 备份路径 -gzip 压缩

数据还原

shell 复制代码
mongorestore \
--host 127.0.0.1 \
--port 20017 \
--username root \
--password 111111 \
--authenticationDatabase admin \
--db ZHIYUN_PROD_MONGO \
--collection DATA_COLLECT_BIG_ORIGIN_2022_11 \
--gzip /opt/docker/mongodb/back/DATA_COLLECT_BIG_ORIGIN_2022_11.bson.gz

!命令说明\]- --host host --port 端口 --username 用户名 --password 密码 --authenticationDatabase --db 库 --collection 集合 -gzip 压缩

相关推荐
花好月圆春祺夏安2 分钟前
基于odoo17的设计模式详解---备忘模式
数据库·设计模式
有想法的py工程师30 分钟前
PostgreSQL 查询库中所有表占用磁盘大小、表大小
数据库·postgresql
R_AirMan2 小时前
深入浅出Redis:一文掌握Redis底层数据结构与实现原理
java·数据结构·数据库·redis
Hello.Reader2 小时前
RedisJSON 内存占用剖析与调优
数据库·redis·缓存
wkj0013 小时前
php 如何通过mysqli操作数据库?
android·数据库·php
九皇叔叔5 小时前
【9】PostgreSQL 之 vacuum 死元组清理
数据库·postgresql
风雅的远行者5 小时前
mysql互为主从失效,重新同步
数据库·mysql
宇钶宇夕6 小时前
S7-1200 系列 PLC 中 SCL 语言的 PEEK 和 POKE 指令使用详解
运维·服务器·数据库·程序人生·自动化
绿蚁新亭6 小时前
Spring的事务控制——学习历程
数据库·学习·spring
scilwb7 小时前
占用栅格地图数据集
数据库