可参考官网教程

复制集增加了数据的冗余同时也提高了mongodb的可靠性,相比传统的主从架构,mongodb具有自动容灾的特性,即主库挂掉后会自动从剩下的从库中选举出一个节点做为主库(不需要人工干预),继续为客户端提供服务。

目前为止,复制集最多只能包含12个节点,但只能有7个投票节点(vote不为0的节点,非arbiter)。

注意:复制集要想正常工作,必须满足二分之一原则,否则所有节点都将降级为从节点,复制集将不能提供写服务。

复制集节点通常部署奇数个,若只有偶数个节点,可添加一个arbiter。

主节点:为客户端提供服务,进行数据读写

从节点:默认情况下,从节点不提供读写服务,若要查看从库内容,需先执行:rs.slaveOk(),主要用于读取主节点opLog,同步主节点数据,起到数据备份的作用,当主节点异常,会进行自动选举,在剩下的从节点中选举出一个成为主节点继续提供服务。

投票节点(arbiter): 不存储数据,主要用于选举是投票。

下面开始接受复制集搭建步骤:

此处假设我有三台服务器,分别为:192.168.103.54, 192.168.103.56, 192.168.103.57

1、在三台服务器上分别安装mongdb

2、修改各mongdb的配置文件:/etc/mongod.conf,执行如下指令

vi /etc/mongod.conf

此处主要修改监听网卡(bindIp)和复制集名称(replSetName),修改后配置文件如下

# mongod.conf

# for documentation of all options, see:
# http://docs.mongodb.org/manual/reference/configuration-options/ # where to write logging data.
systemLog:
destination: file
logAppend: true
path: /var/log/mongodb/mongod.log # Where and how to store data.
storage:
dbPath: /var/lib/mongo
journal:
enabled: true
# engine:
# mmapv1:
# wiredTiger: # how the process runs
processManagement:
fork: true # fork and run in background
pidFilePath: /var/run/mongodb/mongod.pid # location of pidfile # network interfaces
net:
port:
bindIp: 127.0.0.1,192.168.103.54 # Listen to local interface only, comment to listen on all interfaces. #security: #operationProfiling: replication:
replSetName: teejo #sharding: ## Enterprise-Only Options #auditLog: #snmp:

注意:复制集中节点复制集名称必须一致,此处为teejo

3、初始化复制集

启动三台服务器上的mongodb,连接上其中一台,执行如下操作

rs.initiate( {
_id : "teejo", //复制集名称,必须和配置文件中保持一致
members: [
{ _id: , host: "192.168.103.54:27017" },
{ _id: , host: "192.168.103.56:27017" },
{ _id: , host: "192.168.103.57:27017" }
]
})

到此,复制集配置完成。

下面介绍几个复制集状态查看指令

rs.conf()             //输出复制集配置情况,可查看复制集包含的节点,以及各几点配置参数
rs.status() //查看复制集运行状态,可从中看出那个是主那个是从

扩展

当只有单机单实例时也可以以复制集启动,这样做的好处是方便日后扩展

假设我只有服务器:192.168.103.54

执行如下初始化,使其以复制集启动:

rs.initiate( {
_id : "teejo",
members: [
{ _id: , host: "192.168.103.54:27017" }
]
})

之后我又添置了服务器:192.168.103.56,192.168.103.57,将其添加到复制集

执行:

rs.add("192.168.103.56:27017")
rs.add("192.168.103.57:27017")

执行:rs.conf(),可查看到复制集节点添加成功,

若是添加投票节点,调用方法:rs.addArb()

mongdb复制集搭建的更多相关文章

  1. MongoDB之 复制集搭建

    MongoDB复制集搭建步骤,本次搭建使用3台机器,一个是主节点,一个是从节点,一个是仲裁者. 主节点负责与前台客户端进行数据读写交互,从节点只负责容灾,构建高可用,冗余备份.仲裁者的作用是当主节点宕 ...

  2. 【Mongodb】 可复制集搭建

    可复制集 replica set 概念图 可复制集需要至少3个以上的mongodb节点,其中有一个主节点promary,其余的为副本节点secondary 可复制集有三个角色: 主要成员(Primar ...

  3. MongoDB复制集搭建(3.4.17版)

    ==版本== mongodb-linux-x86_64-rhel70-3.4.17.tgz ==准备== 3个节点,我这里的IP及hostname分别是: 10.11.2.52 dscn49 10.1 ...

  4. mongodb复制集搭建

    注:mongodb当前版本是3.4.3 1.准备三个虚拟机做服务器 192.168.168.129:27017 192.168.168.130:27017 192.168.168.131:27017 ...

  5. mongdb 复制集

    步骤: 一.启动三台进程 1../bin/mongod --dbpath=/home/work/app/mongodb/mongodb-linux-x86_64-amazon-3.2.7/data/r ...

  6. 利用Mongodb的复制集搭建高可用分片,Replica Sets + Sharding的搭建过程

    参考资料 reference:  http://mongodb.blog.51cto.com/1071559/740131  http://docs.mongodb.org/manual/tutori ...

  7. mongodb 复制集

    mongodb 复制集 复制集简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写 ...

  8. MongoDB复制集原理、环境配置及基本测试详解

    一.MongoDB复制集概述 MongoDB复制集实现了冗余备份和故障转移两大功能,这样能保证数据库的高可用性.在生产环境,复制集至少包括三个节点,其中一个必须为主节点,一个从节点,一个仲裁节点.其中 ...

  9. MongoDB复制集技术

    复制集搭建 没毛病: https://www.cnblogs.com/nicolegxt/p/6841442.html?utm_source=itdadao&utm_medium=referr ...

随机推荐

  1. jQuery对象的序列化详解

    一.param() 方法创建数组或对象的序列化表示. 该序列化值可在进行 AJAX 请求时在 URL 查询字符串中使用. 语法: jQuery.param(object,traditional) ob ...

  2. http 使用curl发起https请求报错的解决办法

    使用curl发起https请求的时候报错:“SSL certificate problem, verify that the CA cert is OK. Details: error:1409008 ...

  3. Log文件太大,手机ROM空间被占满

    客户要装车,进行项目验收了. 今天拿着几台手机去客户处,其中有一台手机从昨天晚上开始就一直开着我们的APP,今天早晨打开手机发现APP没有反应了. 在程序列表中将其杀掉,然后再启动程序,发现程序不能启 ...

  4. 倍福TwinCAT(贝福Beckhoff)常见问题(FAQ)-如何添加自定义Task,如何让程序的一部分拥有不同的执行周期

    右击Tasks,添加一个新的Task,可以设置这个新的任务的扫描周期,比如100ms   右击PLC的整个的Project,然后Add一个Referenced Task,选中你新建的Task   在P ...

  5. 文字溢出显示省略号,兼容ie9以上浏览器

    最近遇上一个问题,文字溢出展示省略号在ie上不管用,经过查找,是少了word-wrap: normal;这个css属性 width:100px; overflow: hidden; white-spa ...

  6. 算法笔记_055:蓝桥杯练习 Tricky and Clever Password (Java)

    目录 1 问题描述 2 解决方案   1 问题描述 问题描述 在年轻的时候,我们故事中的英雄——国王 Copa——他的私人数据并不是完全安全地隐蔽.对他来说是,这不可接受的.因此,他发明了一种密码,好 ...

  7. PHP中is_*() 函数用法

    PHP中is_*() 函数用法 is_a - 如果对象属于该类或该类是此对象的父类则返回 TRUE is_array - 检测变量是否是数组 is_bool - 检测变量是否是布尔型 is_calla ...

  8. 蓝的成长记——追逐DBA(6): 做事与做人:小技术,大为人

    ***********************************************声明*************************************************** ...

  9. windows下安装UNO,配置AEROO_REPORT (Openoffice4已经升级为Python2.7.5版)

    来自:http://shine-it.net/index.php?topic=8019.msg22007 最近单位要上一个OE,但OE7一天一个新更新,不知何年到头. 闲着没事写一点心得,不敢称为教程 ...

  10. 【leetcode】Reorder List (python)

    问题的思路是这样: 循环取头部合并,事实上也能够换个角度来看,就是将后面的链表结点,一次隔空插入到第一部分的链表中. class Solution: # @param head, a ListNode ...