zoukankan      html  css  js  c++  java
  • 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也成功了。

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

  • 相关阅读:
    Linux安装Memcached服务
    [Shell]随机数
    配置VNC
    Linux挂在ntfs格式的U盘
    大数据入门第五天——离线计算之hadoop(上)概述与集群安装
    Hexo+Github博客搭建
    大数据入门第四天——基础部分之轻量级RPC框架的开发
    大数据入门第三天——基础补充与ActiveMQ
    大数据入门第二天——基础部分之zookeeper(下)
    PowerDesigner安装与使用教程
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/4094383.html
Copyright © 2011-2022 走看看