发表于 2015-7-9 08:36:52

MongoDB Master&Slave

  === 主从同步 ===
  主服务器:192.168.1.5 /Win2003
从服务器:192.168.1.25 /WinXP
  
  1、建立数据库目录
  主服务器:
  D:\Database\MongoDB\db_master
  从服务器:
  D:\Database\MongoDB\db_slave

[*]
分别启动主从服务器  启动主服务器:
  (指定数据存放路径:D:\Database\MongoDB\db_master)
  (指定端口为:1000)
  mongod -dbpath D:\Database\MongoDB\db_master -port 1000 -master
  启动从服务器:
  (指定数据存放路径:D:\Database\MongoDB\db_slave)
  (主数据库地址为:192.168.1.5:1000 )
  (每隔10秒同步一次)
  mongod –dbpath D:\Database\MongoDB\db_slave –source 192.168.1.5:1000 –port 1001 –slave –slavedelay 10
[*]登陆slave从数据库服务器,在slave上添加主机信息:
    mongo 192.168.1.25:1001
[*]加入主机:
    db.sources.insert( { host:192.168.1.5 } );
[*]
在slave从数据库服务器上查看是否和主机连接配置正确
    db.printSlaveReplicationInfo();  如果成功将会出现以下信息
    source:   192.168.1.5:1000
    syncedTo: Fri Mar 26 2010 12:55:19 GMT+0800
         = -10secs ago (0hrs)
    >
[*]测试主从
[*]
在主服务器新建数据库  mongo -port 1000
  show dbs
  use testdb
  db.blog.save({title:"new article"})
  B、在从服务器上查看同步数据
  mongo -port 1001
  show dbs
  use testdb
  db.blog.find()
  === 备份与恢复 ===
[*]
备份数据库:  语法:mongodump -h IP:端口 -d 数据库 -o 文件存在路径
  mongodump -h 127.0.0.1:10000 -d testdb -o D:\Database\Mongo\backup
    -h:MongDB所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:1000
  -d:需要备份的数据库实例,例如:testdb
  -o:备份的数据存放位置,例如:D:\Database\Mongo\backup,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据。
  
  出现以下提示说明备份成功
  connected to: 127.0.0.1 DATABASE: testdb to /data/dump/testdb
      testdb.blog to /data/dump/testdb/blog.bson
               1 objects
      testdb.system.indexes to /data/dump/testdb/system.indexes.bson
               1 objects

[*]
恢复数据库:  语法:mongorestore -h IP -d 目标库 -drop -directoryperdb 源文件
  mongorestore -h 127.0.0.1 -d testdb -directoryperdb D:\Database\Mongo\backup\testdb
  -h:MongoDB所在服务器地址
  -d:需要恢复的数据库实例,例如:testdb,当然这个名称也可以和备份时候的不一样,比如test2
      -directoryperdb:备份数据所在位置,例如:c:\data\dump\test,这里为什么要多加一个test,而不是备份时候的dump,读者自己查看提示吧!
  -drop:恢复的时候,先删除当前数据,然后恢复备份的数据。就是说,恢复后,备份后添加修改的数据都会被删除,慎用哦!

  3、另外mongodb还提供了mongoexport 和 mongoimport 这两个命令来导出或导入数据,导出的数据是json格式的。也可以实现备份和恢复的功能。例:
  mongoexport -d mixi_top_city_prod -c building_45 -q '{ "uid" : "10832545" }' > mongo_10832545.bson
  mongoimport -d mixi_top_city -c building_45 --file mongo_10832545.bson
  -d 数据库
  -c 集合
  -f 字段
  -type 数据文件类型(不知道使用BSON是否可以加快速度)
  -file 导入文件
页: [1]
查看完整版本: MongoDB Master&Slave