zoukankan      html  css  js  c++  java
  • mongo DB 备份与恢复(转)

    mongoexport作用   ==》mongoexport --help
    mongoexport这个工具的作用就是Export data from MongoDB in CSV or JSON format.。将MongoDB中的数据导出为csv或者json格式。

    CSV
    CSV(Comma-Separated Values)–逗号分隔值文件格式。其文件以纯文本形式存储表格数据(数字和文本)。记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号或制表符。

    一些参数说明
    -h, --host=<hostname> 指定MongoDB的主机地址。
    --port=<port>,MongoDB服务器端口,默认是27017
    -d, --db=<database-name>,要导出数据的数据库。
    -c, --collection=<collection-name>,collection名称。
    --type=<type>,导出的数据格式,默认是json。
    -f, --fields=<field>[,<field>]*,指定要导出的字段
    --fieldFile=<filename>,导出为CSV格式时,如果字段很长,可以指定这个参数,一个字段占一行。
    -o, --out=<filename>,保存导出文件的路径和名称
    -u, --username=<username>,用户名,没有设置就不需要指定
    -p, --password=<password>,密码,同样,没有设置不需要指定。

    docker 版本: 

    cd  /user/bin/
    
    导出为csv,字段较少,用fields

    mongoexport --host 127.0.0.1 --port 27017 --db book --collection 'csbook' --type csv --fields _id,book_name,book_url,book_detail,book_author,price,book_pub --out /home/penelope/Desktop/csbook.csv --limit 5

    
    
    
    
    执行:
    
    导出为csv,字段较多时采用 –fieldFile 文件中每个字段独占一行。
    mongoexport --host 127.0.0.1 --port 27017 --db ELSA_MILESTONE_SUBSCRIPTION_SERVICE --collection 'milestone_work_table' --type csv --fieldFile /opt/milestone_work_table.txt --out /opt/milestone_work_table.csv

     

    非docker版本:

    原文:https://www.runoob.com/mongodb/mongodb-mongodump-mongorestore.html

    MongoDB 备份(mongodump)与恢复(mongorestore)


    MongoDB数据备份

    在Mongodb中我们使用mongodump命令来备份MongoDB数据。该命令可以导出所有数据到指定目录中。

    mongodump命令可以通过参数指定导出的数据量级转存的服务器。

    语法

    mongodump命令脚本语法如下:

    >mongodump -h dbhost -d dbname -o dbdirectory
    • -h:

      MongDB所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017

    • -d:

      需要备份的数据库实例,例如:test

    • -o:

      备份的数据存放位置,例如:c:datadump,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据。

    实例

    在本地使用 27017 启动你的mongod服务。打开命令提示符窗口,进入MongoDB安装目录的bin目录输入命令mongodump:

    >mongodump

    执行以上命令后,客户端会连接到ip为 127.0.0.1 端口号为 27017 的MongoDB服务上,并备份所有数据到 bin/dump/ 目录中。命令输出结果如下:

    MongoDB数据备份

    mongodump 命令可选参数列表如下所示:

    语法描述实例
    mongodump --host HOST_NAME --port PORT_NUMBER 该命令将备份所有MongoDB数据 mongodump --host runoob.com --port 27017
    mongodump --dbpath DB_PATH --out BACKUP_DIRECTORY   mongodump --dbpath /data/db/ --out /data/backup/
    mongodump --collection COLLECTION --db DB_NAME 该命令将备份指定数据库的集合。 mongodump --collection mycol --db test

    MongoDB数据恢复

    eg:

    cd /usr/bin
     mongorestore --gzip -h localhost:27017 -u root -p root --authenticationDatabase "admin" -d ELSA_MILESTONE_SUBSCRIPTION_SERVICE /data/configdb/ELSA_MILESTONE_SUBSCRIPTION_SERVICE

    mongodb使用 mongorestore 命令来恢复备份的数据。

    语法

    mongorestore命令脚本语法如下:

    >mongorestore -h <hostname><:port> -d dbname <path>
    • --host <:port>, -h <:port>:

      MongoDB所在服务器地址,默认为: localhost:27017

    • --db , -d :

      需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如test2

    • --drop:

      恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!

    • <path>:

      mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:datadump est。

      你不能同时指定 <path> 和 --dir 选项,--dir也可以设置备份目录。

    • --dir:

      指定备份的目录

      你不能同时指定 <path> 和 --dir 选项。

    接下来我们执行以下命令:

    >mongorestore

    执行以上命令输出结果如下:

    MongoDB数据恢复

  • 相关阅读:
    javaweb(五)——Servlet开发(一)
    JDK1.8改为JDK1.7过程
    javaweb(四)——Http协议(请求头,响应头详解)
    JavaWeb(三)——Tomcat服务器(二)
    JavaWeb(二)——Tomcat服务器(一)
    JavaWeb——JavaWeb开发入门
    java学习之异常总结
    java学习之异常之覆盖
    java学习之异常之格式
    java学习之异常之finally
  • 原文地址:https://www.cnblogs.com/lshan/p/12012017.html
Copyright © 2011-2022 走看看