解决mongodb数据库备份不完整的方法
小编给大家分享一下解决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数据库备份不完整的方法有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。