mongodb迁移

A机器上有mongodb服务,A机器要废,于是迁至B。

简单起见,依旧是在A上ps auxwww|grep mongo找到正在执行的进程:

/home/admin/mongodb/mongodb-linux-x86_64-2.2.0/bin/mongod -f /home/admin/mongodb/mongodb.conf

于是把/home/admin/mongodb/ 拷到B下。

在b 中运行上述命令,把mongo起来了。

以下是数据的恢复。

一、看mongodb.conf中auth=true,可见A中是设了权限的,否则应用代码无法使用,于是在B中也设一下:

/home/admin/mongodb/mongodb-linux-x86_64-2.2.0/bin/mongo进入mongshell

use stats;

db.addUser('webuser','123456');

二、数据导出导入

从A中dump数据:/home/admin/mongodb/mongodb-linux-x86_64-2.2.0/bin/mongodump -d stats -o stat_dump -uwebuser -pxxxxxx

把上述stat_dump文件夹scp至B.

在b中导入:

~/mongodb/mongodb-linux-x86_64-2.2.0/bin/mongorestore -d stats /home/admin/stat_dump/*

其它的都没问题,但是user_behavior这个collection报错:

Tue May 20 11:45:35 going into namespace [stats.user_behavior]

Tue May 20 11:45:35 Assertion failure b.empty() src/mongo/db/json.cpp 645

没明确原因,于是把这个user_behavior数据从stat_dump下删除了,导入。即把别的collection先导进去了,然后再单独处理它。

单独处理它就用export/import的方式了。

先在A上/home/admin/mongodb/mongodb-linux-x86_64-2.2.0/bin/mongoexport -d stats -c user_behavior -o ub -uwebuser -pxxxxxxx

再把ub这个文件scp到B上。

~/mongodb/mongodb-linux-x86_64-2.2.0/bin/mongoimport -d stats -c user_behavior ub

这样这个collection也成功了。

应用代码调一下,能够显示了。

上一篇:php获取客户端ip get_client_ip()


下一篇:Android 打造任意层级树形控件 考验你的数据结构和设计