学习MongoDB(二) Replica Set集群配置
1、官方网址:https://docs.mongodb.org/manual/tutorial/deploy-replica-set-for-testing/
2、Replica Set介绍: https://docs.mongodb.org/manual/core/replica-set-members/
3、简单叙述一下什么是Replica Set:
如果我们使用单一的Mongodb数据库,那么它会存在单点故障等问题,Mongodb允许我们将多个单一的Mongodb数据库组成一个(“集群Replica Set” )对外提供统一的服务。
(“集群Replica Set” )存在如下特性:
1:节点间数据自动同步(主从复制模式,与MYSQL的主从复制原理类似),保证节点间数据是一致的。
2:节点间健康状态检查,故障自动切换,对客户端无影响。
(“集群Replica Set” )当中的角色:
1:主节点(primary)负责接收客户端的读写请求。
2:副节点(secondary)自动从主节点复制数据,可以处理客户端的读请求(决不能处理客户端的写请求)。
3:仲裁节点(arbiter)这里先不做解释,后面说明。

(“集群Replica Set” )运行的过程:
1:主节点(primary)将所有的操作记录到自己的日志当中去,副节点(secondary)会自动去主节点拷贝日志,然后将数据变化同步到自己的数据库中,从而保证数据的一致性。
2:如果集群当中的主节点(primary)发生故障,那么余下可用的副节点(secondary)会自动选举出一个新的主节点,如下图。

3:如果原来出现故障的主节点恢复可用,那么它会再次加入到集群当中,这时他会变成副节点(secondary),然后立即去当前的主节点同步数据,这样就又形成了一个新的集群,是不是很强大。
仲裁节点 (arbiter)说明:
1:仲裁节点(arbiter) 不会存储数据,它的作用是当集群中主节点出现故障时,由它来重新选举一个主节点,由于仲裁节点不存储数据,也不对外提供服务,所以可以运行在配置相对较低的服务器上。

集群当中的成员限制:
1:一个集群中最多有50个成员,也就是50个Mongodb数据库组成的集群。
2:在这50个成员当中,只能有一个【主节点(primary)】,一个【仲裁节点(arbiter)】,七个【参与选举的副节点(secondary)】,余下的数量可以配置任意个【不参与投票的副节点】
3:那些不参与选举的副节点,依然会保数据,对外提供相同的服务,只是不参与选举而已。
4、如何配置集群,此配置在一台机器上模拟集群,降低了一些参数的阀值,有条件的可以在多个机器上配置。
1:创建3个文件夹,用来存放3个数据的数据文件。
mkdir -p /srv/mongodb/rs0-0 /srv/mongodb/rs0-1 /srv/mongodb/rs0-2
2:分别启动3个数据库,端口分别为 27017 27018 27019
mongod --port 27017 --dbpath /srv/mongodb/rs0-0 --replSet rs0 --smallfiles --oplogSize 128
mongod --port 27018 --dbpath /srv/mongodb/rs0-1 --replSet rs0 --smallfiles --oplogSize 128
mongod --port 27019 --dbpath /srv/mongodb/rs0-2 --replSet rs0 --smallfiles --oplogSize 128
--dbpath 为数据库文件存放的目录, --replSet 指定集群的名字,节点间名字需要相同, --smallfiles 最低的资源要求(仅供测试) --oplogSize 用来记录操作的日志的大小M
3:进入到其中一个mongodb中。
mongo --port 27017
4:在mongo shell中定义一个变量,配置成员信息。
rsconf = {
_id: "rs0",
members: [
{
_id: 0,
host: "xxx.xxx.xxx.xxx:27017"
}
]
}
rs.initiate( rsconf ) 初始化集群。
5:加入其它节点,将IP替换为你的服务器外网IP。
rs.add("IP:27018")
rs.add("IP:27019")
6:这时集群一个配置完了,你可以通过rs.status()来查看集群当中每个节点的状态了。
6、集群的配置已经完成,这时你可以在主节点上插入数据,然后在连接到副节点查看,看数据是不是立即同步过来了。
学习MongoDB(二) Replica Set集群配置的更多相关文章
- 学习MongoDB(Troubleshoot Replica Sets) 集群排除故障
Test Connections Between all Members(集群中节点网络测试) 在进行Mongodb集群时,每个节点的网络都需要互动,假设有3个服务器节点. m1.example.ne ...
- MongoDB 学习笔记(三) MongoDB (replica set) 集群配置
MongoDB Replica Sets的结构类似于以集群,完全可以把他当成一个集群,因为他确实与集群实现的作用是一样的:如果其中一个节点出现故障,其他的节点会马上将业务接管过来.而无需停机操作 Mo ...
- 【kafka学习之二】Kafka集群搭建
安装环境 jdk1.7 zookeeper-3.4.5(参考 https://www.cnblogs.com/cac2020/p/9426531.html) VM虚拟机redhat6.5-x64 ...
- 【Kubernetes学习之二】Kubernetes集群安装
环境 centos 7 Kubernetes有三种安装方式:yum.二进制.kubeadm,这里演示kubeadm. 一.准备工作1.软件版本 软件 版本 kubernetes v1.15.3 Cen ...
- hadoop学习(二)hadoop集群的启动
一.完全分布式集群环境的搭建 1.配置hosts文件:将三台集群服务器的主机名与IP的对应关系互相配置到对方的hosts文件中,以便对方服务器能通过主机名寻找IP,hosts文件在/etc目录下. 2 ...
- Redis学习笔记(二):Redis集群
集群通过分片(sharding)来进行数据共享,并提供复制和故障转移功能. 1.节点 一个节点就是一个运行在集群模式下的Redis服务器.启动Redis服务器时,通过判断cluster-enabl ...
- MongoDB高可用集群配置方案
原文链接:https://www.jianshu.com/p/e7e70ca7c7e5 高可用性即HA(High Availability)指的是通过尽量缩短因日常维护操作(计划)和突发的系统崩溃(非 ...
- MongoDB高可用集群配置的方案
>>高可用集群的解决方案 高可用性即HA(High Availability)指的是通过尽量缩短因日常维护操作(计划)和突发的系统崩溃(非计划)所导致的停机时间,以提高系统和应用的可用性. ...
- redis:集群配置
一.redis集群相关 1.概念:redis集群是通过数据分区提供可用性的,这样即使一部分节点失效也可以继续处理请求. 2.原理:集群使用数据分片实现,一个redis集群包括16384个哈希槽,数据库 ...
随机推荐
- python packages prebuild for windows
python prebuild / precompiled packages for windows by uci edu 在python windows环境下作业,有时候会碰上一些无厘头的问 ...
- 10分钟轻松设置出 A+ 评分的 HTTP/2 网站
前言 其实 HTTP/2 应该是 2015 年的老话题了(2015 年 5 月 14 日 HTTP/2 协议正式版的发布),但是 2018 年都到了很多网站依旧没有使用,作为新一代互联网协议,HTTP ...
- Shell脚本:向磁盘中批量写入数据
一.关于本文 工作要做的监控系统需要监控磁盘空间的使用率并报警.在测试这个功能的时候需要模拟两个场景:一是磁盘空间不断增长超过设定的阈值时,需要触发报警机制:二是磁盘空间降落到低于报警阈值的时候,不再 ...
- 转 HystrixDashboard服务监控、Turbine聚合监控
SpringCloud系列七:Hystrix 熔断机制(Hystrix基本配置.服务降级.HystrixDashboard服务监控.Turbine聚合监控) 1.概念:Hystrix 熔断机制 2.具 ...
- Android Manifest.xml文件的结构及作用
原文链接:http://android.eoe.cn/topic/android_sdk 每一个应用程序在工程的根目录下必须要有一个AndroidManifest.xml文件(一定要用这个名称).这个 ...
- ARC指南 strong和weak指针
一.简介 ARC是自iOS 5之后增加的新特性,完全消除了手动管理内存的烦琐,编译器会自动在适当的地方插入适当的retain.release.autorelease语句.你不再需要担心内存管理,因为编 ...
- Atitit js canvas的图像处理类库attilax总结与事业
Atitit js canvas的图像处理类库attilax总结与事业 1.1. 脸部识别JavaScript类库Tracking.js1 1.2. AlloyImage特性1 1.3. CamanJ ...
- 关于Verilog中的几种赋值语句
1. 连续赋值语句(Continuous Assignments) 连续赋值语句是Verilog数据流建模的基本语句,用于对线网进行赋值,等价于门级描述,是从更高的抽象角度来对电路进行描述.连续赋值语 ...
- 四大Java EE容器(Tomcat、JBoss、Resin、Glassfish)之简单比较
转自:http://www.cxybl.com/html/bcyy/java/201106241007.html 现在流行的Java EE容器有很多:Tomcat.JBoss.Resin.Glassf ...
- 通过反射实现圆角ImageView
private void init(){ paint = new Paint(Paint.ANTI_ALIAS_FLAG); roundRect = , , getWidth() , getHeigh ...