加入收藏 | 设为首页 | 会员中心 | 我要投稿 银川站长网 (https://www.0951zz.com/)- 云通信、基础存储、云上网络、机器学习、视觉智能!
当前位置: 首页 > 服务器 > 系统 > 正文

MongoDB进行备份但不完整是什么情况 如何处理好

发布时间:2023-09-06 11:35:34 所属栏目:系统 来源:
导读:这篇文章给大家介绍了“MongoDB进行备份但不完整是怎么回事,如何处理好”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。M

这篇文章给大家介绍了“MongoDB进行备份但不完整是怎么回事,如何处理好”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。

Mongodb自带了mongodump和mongorestore这两个工具来实现对数据的备份和恢复。

mongodump能够在Mongodb运行时进行备份,它的工作原理是对运行的Mongodb做查询,然后将所有查到的文档写入磁盘。

所以一般使用此方法对数据库进行备份时数据是不完整的。

mongodump用法:

C:\Users\Administrator>D:\tool\mongo\bin\mongodump --help

Export MongoDB data to BSON files.

options:

  --help                                produce help message

  -v [ --verbose ]                      be more verbose (include multiple times

                                        for more verbosity e.g. -vvvvv)

  --version                             print the program's version and exit

  -h [ --host ] arg                     mongo host to connect to ( <set

                                        name>/s1,s2 for sets)

  --port arg                            server port. Can also use --host

                                        hostname:port

  --ipv6                                enable IPv6 support (disabled by

                                        default)

  -u [ --username ] arg                 username

  -p [ --password ] arg                 password

  --authenticationDatabase arg          user source (defaults to dbname)

  --authenticationMechanism arg (=MONGODB-CR)

                                        authentication mechanism

  --dbpath arg                          directly access mongod database files

                                        in the given path, instead of

                                        connecting to a mongod  server - needs

                                        to lock the data directory, so cannot

                                        be used if a mongod is currently

                                        accessing the same path

  --directoryperdb                      each db is in a separate directly

                                        (relevant only if dbpath specified)

  --journal                             enable journaling (relevant only if

                                        dbpath specified)

  -d [ --db ] arg                       database to use

  -c [ --collection ] arg               collection to use (some commands)

  -o [ --out ] arg (=dump)              output directory or "-" for stdout

  -q [ --query ] arg                    json query

  --oplog                               Use oplog for point-in-time

                                        snapshotting

  --repair                              try to recover a crashed database

  --forceTableScan                      force a table scan (do not use

                                        $snapshot)

参数说明:

-h:指明数据库宿主机的IP

-u:指明数据库的用户名

-p:指明数据库的密码

-d:指明数据库的名字

-c:指明collection的名字

-o:指明到要导出的文件名

-q:指明导出数据的过滤条件

备份的命令:

mongodump -h dbhost -d dbname -o dbdirectory

如果mongodb设置了登录验证,则不能备份成功,报错如下:

assertion: 18 { code: 18, ok: 0.0, errmsg: "auth fails" }

则需要登录,命令如下:

C:\Users\Administrator>D:\tool\mongo\bin\mongodump -username root -password 12345

6 -d test -o d:\tool\mongo\backup

若要备份全部数据库文件可以使用下面的命令进行备份:

C:\Users\Administrator>D:\tool\mongo\bin\mongodump -u root -p 12345

或使用rsync直接拉去数据。

(编辑:银川站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章