小编给大家分享一下解决mongodb数据库备份不完整的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

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

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

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

mongodump用法:

C:\Users\Administrator>D:\tool\mongo\bin\mongodump--helpExportMongoDBdatatoBSONfiles.options:--helpproducehelpmessage-v[--verbose]bemoreverbose(includemultipletimesformoreverbositye.g.-vvvvv)--versionprinttheprogram'sversionandexit-h[--host]argmongohosttoconnectto(<setname>/s1,s2forsets)--portargserverport.Canalsouse--hosthostname:port--ipv6enableIPv6support(disabledbydefault)-u[--username]argusername-p[--password]argpassword--authenticationDatabaseargusersource(defaultstodbname)--authenticationMechanismarg(=MONGODB-CR)authenticationmechanism--dbpathargdirectlyaccessmongoddatabasefilesinthegivenpath,insteadofconnectingtoamongodserver-needstolockthedatadirectory,socannotbeusedifamongodiscurrentlyaccessingthesamepath--directoryperdbeachdbisinaseparatedirectly(relevantonlyifdbpathspecified)--journalenablejournaling(relevantonlyifdbpathspecified)-d[--db]argdatabasetouse-c[--collection]argcollectiontouse(somecommands)-o[--out]arg(=dump)outputdirectoryor"-"forstdout-q[--query]argjsonquery--oplogUseoplogforpoint-in-timesnapshotting--repairtrytorecoveracrasheddatabase--forceTableScanforceatablescan(donotuse$snapshot)

参数说明:

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

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

-p:指明数据库的密码

-d:指明数据库的名字

-c:指明collection的名字

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

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

备份的命令:

mongodump-hdbhost-ddbname-odbdirectory

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

assertion:18{code:18,ok:0.0,errmsg:"authfails"}

则需要登录,命令如下:

C:\Users\Administrator>D:\tool\mongo\bin\mongodump-usernameroot-password123456-dtest-od:\tool\mongo\backup

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

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

或使用rsync直接拉去数据。

看完了这篇文章,相信你对解决mongodb数据库备份不完整的方法有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!