一、MongoDB副本集(repl set)介绍

早起版本使用master-slave,一主一从和MySQL类似,但slave在此架构中为只读,当主库宕机后,从库不能自动切换为主;

目前已经淘汰了master-slave模式,改为副本集,这种模式下有一个主(primary),和多个从(secondary),只读,支持给他们设置权重,当主宕掉后,权重最高的从切换为主;

在此架构中还可以建立一个仲裁(arbiter)的角色,它只负责裁决,而不存储数据

在此架构中读写数据都是在主上,要想实现负载均衡的目的需要手动指定读库的目标server

二、MongoDB副本集搭建

服务器环境准备

三台服务器都是CentOS release 6.5 (Final)

192.168.1.203(primary)

192.168.1.201(secondary)

192.168.1.202(secondary)

编辑三台机器的配置文件,加入如下内容

replication:

oplogSizeMB: 20 #oplog大小

replSetName: fansik #名称自定义

重启三台MongoDB服务

连接主,在主上运行命令mongo,然后

> use admin

>config={_id:"fanjinbao",members:[{_id:0,host:"192.168.1.203:27017"},{_id:1,host:"192.168.1.201:27017"},{_id:2,host:"192.168.1.202:27017"}]}

> rs.initiate(config)

> rs.add("192.168.1.201")

> rs.add("192.168.1.202")

> rs.status() # 查看状态

如果两台从上的状态为"stateStr" : "STARTUP",则需要进行如下操作> var config={_id:"fanjinbao",members:[{_id:0,host:"192.168.1.203:27017"},{_id:1,host:"192.168.1.201:27017"},{_id:2,host:"192.168.1.202:27017"}]}

> rs.initiate(config)

此时再次查看rs.status()会发现从的状态变为SECONDARY

三、MongoDB副本集测试

主上建库建集合

use mydb

db.acc.insert({AccountID:1,UserName:"123",passwd:"123456"})

show dbs

从上查看

show dbs如果出现系列错误

2016-05-13T00:03:36.719+0800 E QUERY    Error: listDatabases failed:{ "note" : "from execCommand", "ok" : 0, "errmsg" : "not master" }

执行

rs.slaveOk()

show dbs就可以看到创建的数据库了

四、副本集更改权重模拟主宕机

默认三台机器权重都为1,如果任何一个权重设置为比其他的高,则该台机器马上切换为primary角色,所以我们预设三台机器的权重为别为203:3,201:2,202:1

在主上执行:

cfg = rs.conf()

cfg.members[0].priority = 3

cfg.members[1].priority = 2

cfg.members[2].priority = 1

rs.reconfig(cfg)

这样的话,第二个节点将会成为候选节点

主上丢弃掉从端口27017进入的数据包

iptables -I INPUT -p tcp --dport 27017 -j DROP

五、MongoDB备份和恢复

备份指定库

# mongodump -h ip -d dbname -o dir #-h后面跟服务器ip,-d后面跟database名字,不加则备份所有库,-o指定备份到哪里,他是一个目录

备份所有库

# mongodump -h 192.168.1.203 -o /tmp/

备份指定集合

# mongodump -d fansik -c zhangsan -o /tmp/fansik #-c指定集合的名字

导出集合为json文件

# mongoexport -d mydb -c fansik -o /tmp/test.json #-o后面跟的是一个文件的名字

恢复所有库

# mongorestore --drop dir/ #其中dir是备份所有库的目录名字 其中--drop可选,意思恢复前先将数据删除,不建议使用

恢复指定库

# mongorestore -d mydb /mydb #-d恢复的库名字,mydb是该库备份目录

恢复集合

# mongorestore -d mydb -c zhangsan /fansik/zhangsan.bson #-c后面是要恢复的集合的名字,然后指定恢复的集合文件,bson格式的文件

导入集合

# mongoimport -d mydb -c test --file /tmp/test.json

MongoDB副本集搭建及备份恢复的更多相关文章

  1. windows版本 MongoDB副本集搭建及开启身份验证

    ------------恢复内容开始------------ ------------恢复内容开始------------ MongoDB副本集搭建 我搭建的是一个主节点,两个副节点 构建目录结构如下 ...

  2. mongodb副本集搭建过程中的问题和解决技巧

    在我以往的认知中,一个系统一旦正式上线,多半不会轻易的迁移服务器,尤其是那种涉及到多个关联应用,涉及到多台硬件服务器的系统,因为这种迁移将是牵一发而动全身的. 但是,却仍然有这种情况存在,就如我这几天 ...

  3. MongoDB 副本集搭建

    搭建mongodb副本集 [root@ mongodb]# cd /u02 [root@ u02]# mkdir -p mongodb/data_2777 [root@ u02]# mkdir -p ...

  4. MongoDB副本集--Secondary节点实例恢复

    场景描述 MongoDB副本集中有一台Secondary节点出现RECOVERING的状态 状态如下: arps:RECOVERING> rs.status() { "set" ...

  5. MongoDB 副本集搭建 & 副本集扩容

    副本集的搭建 创建多实例目录 [root@redis03 ~]# mkdir /server/mongodb/2801{7,8,9}/{conf,logs,pid,data} -p 编辑多实例配置文件 ...

  6. Mongodb副本集搭建经验

    一.环境配置经验 1.一般安装的副本集的时候,主实例可以有数据库和用户:从实例不能.仲裁机不能有任何数据库包括用户 2.搭建副本集的时候Host使用外网IP,否则使用Mongodb VUE 1.6.9 ...

  7. mongodb副本集搭建

    1.创建目录 mkdir -p /data/r1  /data/r2  /data/r3 2.启动: bin/mongod --config ../mongod.conf --replSet r1 b ...

  8. 在centos7上搭建mongodb副本集

    1.安装副本集介绍 副本集(Replica Set)是一组MongoDB实例组成的集群,由一个主(Primary)服务器和多个备份(Secondary)服务器构成.通过Replication,将数据的 ...

  9. mongodb 4.0副本集搭建

    近期有同学问mongodb副本集难不难部署,我的回答是不难,很快,几分钟搞定,比mysql MHA简单的不止一点半点. 那么到底如何部署呢?请看下文. 1.  准备工作 1.1 下载软件 选择版本并下 ...

随机推荐

  1. Android打开新的Activity并同时关闭当前Activity

    Intent it = new Intent(); it.setClass(EditActivity.this, MainActivity.class); it.setFlags(Intent.FLA ...

  2. Spring学习笔记之整合hibernate

    1.web.xml里边要配置好对应的springxml的路径 <context-param> <param-name>contextConfigLocation</par ...

  3. Android 时间戳的转换

    在Android应用中,经常会碰到后台的时间是时间戳而现实的需要今天什么时候,昨天什么时候,就像微博的时间显示一样.现在我上一个把时间戳转换的代码: public static String getT ...

  4. C/C++文件结构

    总结者:kate (1).h 为头文件:存放 版权和版本声明,预处理块 ,函数和类结构声明 (2).cpp文件:代码文件,存放程序的实现 大都数时候,源文件和头文件是对应出现的,比如有一个A.cpp  ...

  5. Linear Predictors

    In this chapter we will study the family of linear predictors, one of the most useful families of hy ...

  6. ODI 11g & 12c中缓慢变化维(SCD)的处理机制

    缓慢变化维(Slowly changing Dimensions)指的是维表中的维度字段值会随着时间或业务调整,而在后续的分析中,历史数据仍然要使用旧的维度值,新的数据会使用当前维度值.在数据仓库建设 ...

  7. HTML--7JavaScript的DOM操作

    1.DOM的基本概念 DOM是文档对象模型,这种模型为树模型:文档是指标签文档:对象是指文档中每个元素:模型是指抽象化的东西. 2.Window对象操作 一.属性和方法: 属性(值或者子对象): op ...

  8. form表单select联动

    下拉列表:二级联动菜单 Select对象的常用属性 options[]:返回所有option组成的一个数组: name:名称 value:option的value的值 length:设置或读取opti ...

  9. Add a stylesheet link programmatically in ASP.NET

    Here’s a code snippet used to programmatically insert a stylesheet link to an external CSS file: // ...

  10. select2美化下拉单

    http://www.51xuediannao.com/js/jquery/select2.html http://www.51xuediannao.com/demo.php