网上的资料太乱了,等弄好了再看官网才发现官网写的最清晰和简洁
 
从概念上说一下MongoDB副本集和主从复制的区别。其实副本集(Replica Set)是主从复制的高级形式。高级在哪里呢?主动复制实现了数据备份+读扩展,但是master一旦down掉,需要手动启动slave。副本集在此基础上实现了备份自动重启的功能,也就是某一台slave会挺身而出,担当起master的职责。所以有三个角色,master(Primary),slave(Secondary),还有仲裁服务器。
 
环境:win7,MongoDB3.2 
副本集优势:副本集实现了备份自动重启的功能,也就是master一旦down掉,无需手动启动slave ,某一台会自动slave挺身而出,担当起master的职责,维持数据库的读写操作
目标:
一台master(primary):master 127.0.0.1:5555
三台slave(secondary):mslave1 127.0.0.1:6666 ;   mslave2 127.0.0.1:7777 ;  mslave3 192.168.228.134:27017
其中192.168.228.134是我虚拟机win7的地址,都是64位
 
第一步:基本配置
略过mongodb的安装和基本操作,见我另一篇博文:http://www.cnblogs.com/leskang/p/6000852.html
 
第二步:设置master服务器
1、手动创建四个服务实例的文件目录,,并配置好各自bin目录的环境变量,我本地的话只要配置一次
127.0.0.1:5555  对应 本机D:\mongodata\5555
127.0.0.1:6666 对应 本机D:\mongodata\6666
127.0.0.1:7777  对应 本机E:\mongodata\7777
192.168.228.134:27017  对应 虚拟机D:/data
 
2、启动本地127.0.0.1:5555的服务器副本集实例,作为master
cmd打开命令提示符,运行
mongod --dbpath D:\mongodata\5555 --replSet mySet --port 5555 
启动服务后,另打开一个命令提示符进行登陆
mongo --port 5555
接着定义变量,运行:
conf = {_id:"mySet",members:[{_id:0,host:"127.0.0.1:5555"}]}  
回车
接着运行:
rs.initiate(conf) 
回车显示如下:
 
接着你输入:
db.isMaster() 
会显示出你的当前数据库服务实例已经加到副本集中,并且是master,如图:
 
 
第三步:启动本地其他的服务,加入到副本集中,即127.0.0.1:5555和127.0.0.1:6666
打开2个命令提示符,分别输入并回车
mongod --dbpath D:\mongodata\6666 --replSet mySet --port 6666
mongod --dbpath E:\mongodata\7777 --replSet mySet --port 7777  
另外在本地打开命令提示符,登陆master:
mongo --port 27017  
接着添加刚刚那2个服务实例到副本集中,分别输入并回车:
rs.add("127.0.0.1:6666")
rs.add("127.0.0.1:7777")
显示如下:
添加成功了,此时你可以登陆任意机器输入rs.status()查看集合,我登陆的是slave  127.0.0.1:7777
如图:
 
 
第四步:添加虚拟机的数据库服务器到副本集中
即192.168.228.134:27017
方法基本同上:到虚拟机中先启动服务,同样运行
mongod --dbpath d:/data --replSet mySet --port 27017  
接着回到本机,打开命令提示符,登陆master
mongo --port 27017  
同上接着添加虚拟机的服务到副本集中
rs.add("192.168.228.134:27017")  
一切ok了
测试:
1 登陆master 插入一些数据,再去slave里看 同样存在,复制成功。
  注意:新建的slave是不能读和写的,当在从服务器上读时会出现errmsg:not master and slaveOk=flase code:13435 错误,需要执行:rs.slaveOk()来开启读功能
2 关闭master的窗口(即停止master服务)后,原来的master无法访问,另外的一个slave变成了master,依然可以正常添加修改数据
3 登录任意服务实例,运行rs.isMaster()可以查看当前服务是否是master,运行rs.status()查看副本群内部情况
 
 

mongodb3.2副本集配置的更多相关文章

  1. [Database] MongoDB 副本集配置

    MongoDB 副本集配置 MongoDB复制是将数据同步在多个服务器的过程. 复制提供了数据的冗余备份,并在多个服务器上存储数据副本,提高了数据的可用性, 并可以保证数据的安全性. 复制还允许您从硬 ...

  2. 分布式文档存储数据库(MongoDB)副本集配置

    副本集特征: N 个节点的集群 任何节点可作为主节点 所有写入操作都在主节点上 自动故障转移 自动恢复 相关文章: http://www.cnblogs.com/huangxincheng/archi ...

  3. mongodb系列之---副本集配置与说明

    在配置副本集之前,我们先来了解一些关于副本集的知识. 1,副本集的原理 副本集的原理与主从很相似,唯一不同的是,在主节点出现故障的时候,主从配置的从服务器不会自动的变为主服务器,而是要通过手动修改配置 ...

  4. MongoDB副本集配置系列三:副本集的认证方式

    1:副本集配置参考这篇博客: http://www.cnblogs.com/xiaoit/p/4478951.html 2:副本集的认证 假设有两台机器已经配置好了副本集(副本集罪一般最少3台机器,这 ...

  5. Mongodb3.0.5副本集搭建及spring和java连接副本集配置

    这是去年写的一篇文档,最近突然发现并没有发不出来,因此现在补上,希望能对某些朋友有所帮助.因为当时记录时没有截图,因此这里看起来可能就比较单调. 一.基本环境: mongdb3.0.5数据库 spri ...

  6. MongoDB系列之三(副本集配置)

    今天我测试了一下MongoDB的副本集的配置. 首先从概念上说一下MongoDB副本集和主从复制的区别.其实副本集(Replica Set)是主从复制的高级形式.高级在哪里呢?主动复制实现了数据备份+ ...

  7. mongodb副本集配置

    需要用到mongodb的时候单个实例肯定是不行的,挂了怎么办,那然后呢,跟mysql一样搞主从备份吗,是可以的mongodb这么弄,不过官网已经不推荐了这么干了,推荐使用副本集的模式,然后数据再大一点 ...

  8. mongodb3.0副本集搭建补充~~非admin数据库的用户权限

    之前有搭建mongodb3.0的副本集,不过当时直接使用的admin数据库,用户也是直接给的root. 链接:http://blog.csdn.net/tuzongxun/article/detail ...

  9. mongodb3.6 副本集(三)mongodb 如何做数据备灾

    前言 个人理解,副本集一个主要作用就是当Master库出现故障,其中的一个salve从库会被选举出来成为新的Master.框架图如下: 其中,选举者是不参与数据存储的,它的作用只是为了选举出新的Mas ...

随机推荐

  1. 6 springboot Docker 部署

    安装请参考其他的教程请参考http://www.runoob.com/docker/centos-docker-install.htm 拉取zookeeper镜像 docker pull zookee ...

  2. SecureCRT远程连接Linux下的sqlplus中退格键不能使用之解决方法

    ^H不是H键的意思,是backspace 主要是当你的终端backspace有问题的时候才需要设置   在linux环境下使用sqlplus,在回删(backspace)时往往会出现 一串的乱码.出现 ...

  3. 【SSH网上商城项目实战05】完成数据库的级联查询和分页

    转自:https://blog.csdn.net/eson_15/article/details/51320212 上一节我们完成了EasyUI菜单的实现.这一节我们主要来写一下CategorySer ...

  4. HTML颜色的三种写法

    颜色的三种写法: 1.16进制代码     #000000 2.英文字母         red 3.rgba                rgba(0-255,0,0,0-1) 例如: <b ...

  5. Ueditor更改编辑框样式

    1.在ueditor.all.min.js文件中查找“ueditor.css”,找到位置后更改css文件,或在原文件中更改

  6. JavaScript的进阶之路(五)理解数组1

    数组是值得有序结合,每个值叫做一个元素,每个元素的位置称为索引,索引从0开始. 在JavaScript中,数组是对象的特殊形式.继承自Array.prototype中的属性,有丰富的数组操作方法. 通 ...

  7. 学习servlet心得

    1,关于字符编码问题: // resp.setCharacterEncoding("UTF-8");//这个的作用仅仅只是输出字符,不做格式转换成HTML // resp.setC ...

  8. 用Jmeter进行接口测试及乱码问题

    web接口测试工具: 手工测试的话可以用postman ,自动化测试多是用到 Jmeter(开源).soupUI(开源&商业版). 下面将对前一篇Postman做接口测试中的接口用Jmeter ...

  9. 网络虚拟化技术 -- LXC TUN/TAP MACVLAN MACVTAP

    Linux的网络虚拟化是LXC项目中的一个子项目,LXC包括文件系统虚拟化,进程空间虚拟化,用户虚拟化,网络虚拟化,等等 [ LXC内核命名空间 ],这里使用LXC的网络虚拟化来模拟多个网络环境. 创 ...

  10. TPS和事务响应时间的关系、计算公式 (转)

    例子:一个高速路有10个入口,每个入口每秒钟只能进1辆车1.请问1秒钟最多能进几辆车?   TPS=102.每辆车需要多长时间进行响应?   reponse time = 13.改成20辆车,每秒能进 ...