mongdb复制集搭建
可参考官网教程
复制集增加了数据的冗余同时也提高了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复制集搭建的更多相关文章
- MongoDB之 复制集搭建
MongoDB复制集搭建步骤,本次搭建使用3台机器,一个是主节点,一个是从节点,一个是仲裁者. 主节点负责与前台客户端进行数据读写交互,从节点只负责容灾,构建高可用,冗余备份.仲裁者的作用是当主节点宕 ...
- 【Mongodb】 可复制集搭建
可复制集 replica set 概念图 可复制集需要至少3个以上的mongodb节点,其中有一个主节点promary,其余的为副本节点secondary 可复制集有三个角色: 主要成员(Primar ...
- MongoDB复制集搭建(3.4.17版)
==版本== mongodb-linux-x86_64-rhel70-3.4.17.tgz ==准备== 3个节点,我这里的IP及hostname分别是: 10.11.2.52 dscn49 10.1 ...
- mongodb复制集搭建
注:mongodb当前版本是3.4.3 1.准备三个虚拟机做服务器 192.168.168.129:27017 192.168.168.130:27017 192.168.168.131:27017 ...
- mongdb 复制集
步骤: 一.启动三台进程 1../bin/mongod --dbpath=/home/work/app/mongodb/mongodb-linux-x86_64-amazon-3.2.7/data/r ...
- 利用Mongodb的复制集搭建高可用分片,Replica Sets + Sharding的搭建过程
参考资料 reference: http://mongodb.blog.51cto.com/1071559/740131 http://docs.mongodb.org/manual/tutori ...
- mongodb 复制集
mongodb 复制集 复制集简介 Mongodb复制集由一组Mongod实例(进程)组成,包含一个Primary节点和多个Secondary节点,Mongodb Driver(客户端)的所有数据都写 ...
- MongoDB复制集原理、环境配置及基本测试详解
一.MongoDB复制集概述 MongoDB复制集实现了冗余备份和故障转移两大功能,这样能保证数据库的高可用性.在生产环境,复制集至少包括三个节点,其中一个必须为主节点,一个从节点,一个仲裁节点.其中 ...
- MongoDB复制集技术
复制集搭建 没毛病: https://www.cnblogs.com/nicolegxt/p/6841442.html?utm_source=itdadao&utm_medium=referr ...
随机推荐
- SparkSQL之更改表结构
本文篇幅较短,内容源于自己在使用SparkSQL时碰到的一个小问题,因为在之后的数据处理过程中多次使用,所以为了加深印象,在此单独成文,以便回顾. 场景 在使用SparkSQL进行数据处理时,碰到这样 ...
- [置顶] (奇迹冬瓜)坦克大战[MFC框架]
经过二次整合 重新放出MFC框架下的坦克大战 采用小窗口 多线程 双缓冲 动画帧化 碰撞检测 接口封装 混音 事件延迟等 力求做到代码与美工的双向化 开场动画 界面一 界面二 游戏界面 结束动画 零积 ...
- json字符串跟objective-c模型的相互转换
在当今这样一个各种openapi开放的年代,在熟悉的语言下面找到一款得心应手的将json字符串转换成模型的库可以说是十分必要的,在NET平台下,我们有Newtonsoft.Json这个库使用,那么在i ...
- 使用airdrop进行文件共享
使用airdrop进行文件共享 学习了: https://support.apple.com/zh-cn/HT203106 https://zh.wikihow.com/%E5%9C%A8Mac%E4 ...
- 说说C#之父——安德斯·海尔斯伯格
安德斯·海尔斯伯格(Anders Hejlsberg,1960.12~),丹麦人,Turbo Pascal编译器的主要作者,Delphi和.NET之父! 看到照片的那一刹那儿,我就觉得帅爆了,53岁的 ...
- Spring之替换Bean的返回结果,替换Bean的方法实例
Spring是一个非常强悍的框架+容器,其中有代理模式(动态代理模式)的极致体现.下面是两个比较让人感觉精彩的代码使用,重点关注main方法中的ClassPathXMlApplicationConte ...
- 基于Prometheus搭建SpringCloud全方位立体监控体系
前提 最近公司在联合运维做一套全方位监控的系统,应用集群的技术栈是SpringCloud体系.虽然本人没有参与具体基础架构的研发,但是从应用引入的包和一些资料的查阅大致推算出具体的实现方案,这里做一次 ...
- Excle中range的一些用法
以下是一些range的简单用法 Sub aa() '-=============================================== '给B列设置填充颜色为黄色 Range(" ...
- (一)Solr——简介和安装配置
1. solr简介 1.1 Solr是什么 Solr是apache的顶级开源项目,它是使用java开发 ,基于lucene的全文检索服务器. Solr和lucene的版本是同步更新的,最新的版本是7. ...
- Mybatis准备
http://www.mybatis.org/mybatis-3/zh/index.html