Mongodb

MongoDb 数据迁移

2019-08-16  本文已影响0人  Sdoopy

公司买了一台服务器,要做数据迁移。大概有20G的样子。原数据库存放服务器A 目标数据库存放服务器B

数据备份

mongodump -h <hostname><:port> -d dbname -u username -p password -o dbdirectory 

-h:
MongDB所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017。
-d:
需要备份的数据库实例,例如:test
-o:
备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据。
-u 连接远程数据库的账户,若数据库设置了认证,需指定账户。
-p 连接远程数据库账户对应的密码

因为是内网迁移,所以这里可以在目标数据库存放服务器B上 进行原数据库的备份,要直接写原数据库所在的ip port。

mongodump -h A:27017 -u username -p password -d test -o /root/data

这样备份完之后,会在/root/data 下生成一个test的文件夹

数据恢复

mongorestore -h <hostname><:port> -d dbname <path>

--host <:port>, -h <:port>:
MongoDB所在服务器地址,默认为: localhost:27017
--db , -d :
需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如test2
--drop:
恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!
<path>:
mongorestore 最后的一个参数,设置备份数据所在位置,例如:c:\data\dump\test。
你不能同时指定 <path> 和 --dir 选项,--dir也可以设置备份目录。

现在已经在B服务器上了,所以-h可以略去,使用默认。

mongorestore -d test  -u username -p password /root/data/test

这里的path不能写/root/data,看到有些资料上会直接这么写,尝试之后是不行的,必须要加上数据库的名称。到这里数据就迁移好了。

希望能帮到你们:)

上一篇下一篇

猜你喜欢

热点阅读