mongoDB之Replica Set集群安装

2024-01-10 15:18

本文主要是介绍mongoDB之Replica Set集群安装,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Replica Set准确讲不完全是集群,只是一个主从复制的加强版

概念如下:

primary:主节点客户端写操作发生在这里。

secondary:副本,可以负载读操作,通过复制primary的oplog来实现数据同步

arbiter:仲裁节点,作用是当primary宕掉之后从secondarys选择一个变成primary



 

环境准备:

linux系统版本:

 

$ cat /proc/version
Linux version 2.6.32-358.el6.x86_64 (mockbuild@x86-022.build.eng.bos.redhat.com) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-3) (GCC) ) #1 SMP Tue Jan 29 11:47:41 EST 2013

三台服务器,详情如下:

 

 

192.168.38.17   --primary
192.168.38.18   --secondary
192.168.38.19   --arbiter

mongoDB版本:

 

mongodb-linux-x86_64-2.6.9

安装部署:

1.配置primary.conf,secondary.conf和arbiter.conf

#primary.conf:

 

#primary.conf
dbpath=/home/admin/data/p
logpath=/home/admin/log/primary.log
pidfilepath=/home/admin/data/primary.pid
directoryperdb=true
logappend=true
replSet=testrs
bind_ip=192.168.38.17
port=27017
oplogSize=10000
fork=true
noprealloc=true

#secondary.conf:

 

 

#secondary.conf
dbpath=/home/admin/data/s
logpath=/home/admin/log/secondary.log
pidfilepath=/home/admin/data/secondary.pid
directoryperdb=true
logappend=true
replSet=testrs
bind_ip=192.168.38.18
port=27017
oplogSize=10000
fork=true
noprealloc=true

#arbiter.conf:

 

 

dbpath=/home/admin/data/a
logpath=/home/admin/log/arbiter.log
pidfilepath/home/admin/data/arbiter.pid
directoryperdb=true
logappend=true
replSet=testrs
bind_ip=192.168.38.19
port=27017
oplogSize=10000
fork=true
noprealloc=true

上述配置文件最好在每个集群上都放置,这样就能保证配置文件一致

2.启动

 

分别在不同的节点上加载不同的配置

192.168.38.17启动:

 

bin/mongod -f /home/admin/mongodb/primary.conf

192.168.38.18启动:

 

 

bin/mongod -f /home/admin/mongodb/secondary.conf

192.168.38.19启动:

bin/mongod -f /home/admin/mongodb/arbiter.conf

3.登陆系统配置各个节点

bin/mongo 192.168.38.17:27017   

执行如下命令:

>use admin
>cfg={"_id": "testrs","members": [{"_id": 0,"host": "192.168.38.17:27017","priority": 2},{"_id": 1,"host": "192.168.38.18:27017","priority": 1},{"_id": 2,"host": "192.168.38.19:27017","arbiterOnly": true}]
}; 
>rs.initiate(cfg)  

此时配置已生效,可以通过命令查看相应的信息

4.查看目前各个节点的状态:

rs.status()

结果如下:

{"set" : "testrs","date" : ISODate("2015-04-03T09:02:29Z"),"myState" : 1,"members" : [{"_id" : 0,"name" : "192.168.38.17:27017","health" : 1,"state" : 1,"stateStr" : "PRIMARY","uptime" : 21104,"optime" : Timestamp(1428032802, 2),"optimeDate" : ISODate("2015-04-03T03:46:42Z"),"electionTime" : Timestamp(1428030689, 1),"electionDate" : ISODate("2015-04-03T03:11:29Z"),"self" : true},{"_id" : 1,"name" : "192.168.38.18:27017","health" : 1,"state" : 2,"stateStr" : "SECONDARY","uptime" : 21070,"optime" : Timestamp(1428032802, 2),"optimeDate" : ISODate("2015-04-03T03:46:42Z"),"lastHeartbeat" : ISODate("2015-04-03T09:02:27Z"),"lastHeartbeatRecv" : ISODate("2015-04-03T09:02:28Z"),"pingMs" : 0,"syncingTo" : "192.168.38.17:27017"},{"_id" : 2,"name" : "192.168.38.19:27017","health" : 1,"state" : 7,"stateStr" : "ARBITER","uptime" : 21070,"lastHeartbeat" : ISODate("2015-04-03T09:02:29Z"),"lastHeartbeatRecv" : ISODate("2015-04-03T09:02:29Z"),"pingMs" : 0}],"ok" : 1
}

此时配置已经完成,kill主节点之后查看状态会自动切换

 

PS:默认情况下副本是不会负载读操作的,如果打算让副本负载一部分读操作那么可以参见另外一篇博客

这篇关于mongoDB之Replica Set集群安装的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/591222

相关文章

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

Python库 Django 的简介、安装、用法入门教程

《Python库Django的简介、安装、用法入门教程》Django是Python最流行的Web框架之一,它帮助开发者快速、高效地构建功能强大的Web应用程序,接下来我们将从简介、安装到用法详解,... 目录一、Django 简介 二、Django 的安装教程 1. 创建虚拟环境2. 安装Django三、创

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Jenkins的安装与简单配置过程

《Jenkins的安装与简单配置过程》本文简述Jenkins在CentOS7.3上安装流程,包括Java环境配置、RPM包安装、修改JENKINS_HOME路径及权限、启动服务、插件安装与系统管理设置... 目录www.chinasem.cnJenkins安装访问并配置JenkinsJenkins配置邮件通知

Win10安装Maven与环境变量配置过程

《Win10安装Maven与环境变量配置过程》本文介绍Maven的安装与配置方法,涵盖下载、环境变量设置、本地仓库及镜像配置,指导如何在IDEA中正确配置Maven,适用于Java及其他语言项目的构建... 目录Maven 是什么?一、下载二、安装三、配置环境四、验证测试五、配置本地仓库六、配置国内镜像地址

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也