Cent OS 7.3 安装Mongodb 3.4 Replica Set

本文主要记录mongodb的Replica Set集群方式(如图1),该集群由Primary(主节点)、Secondary(从节点)、Arbiter(投票节点),三种节点组成,其中Primary、Secondary节点数据同步,Arbiter节点不存储数据,只有在Primary节点宕机时做投票选出新的Primary节点用。本次将用最少的节点来模拟集群服务。

原文地址: https://docs.mongodb.com/manual/introduction/
https://docs.mongodb.com/v2.4/reference/replica-configuration/

拓扑如下:

图1
这里写图片描述
图2
这里写图片描述
一、安装MongoDB 3.4。为图方便,直接设置官方yum源安装rpm包(官方推荐)

vi /etc/yum.repos.d/mongodb-org-3.4.repo
    [mongodb-org-3.4]
    name=MongoDB Repository
    baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.4/x86_64/
    gpgcheck=1
    enabled=1
    gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc
yum clean all
yum install -y mongodb-org

二、关掉selinux,并开放27017端口

sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config    #相当于编辑该文件
setenforce 0        #暂时让selinux失效,免得重启服务器
firewall-cmd --permanent --add-port=27017/tcp    #开放端口
firewall-cmd --reload        #重新加载服务,使开放端口命令生效

三、启动服务

mkdir -p /data/db        #创建默认数据库路径
mongod --replSet rs0 &    #启动mongodb服务,并指定集群名为rs0 ,&表示在后台运行
mongo            #进入mongodb服务命令行模式
>rs.add("mongodb1.example.net")        #添加节点1,因为只有一个,默认为primary
>rs.add("mongodb2.example.net")        #添加节点2,因为节点1已经添加,自动成为secondary
>rs.addArb("arbiter.example.net")        #添加arbiter节点,投票(仲裁)节点,无数据
>rs.status()                    #查看当前节点状态

四、连接服务:http://www.mongoing.com/archives/2642
MongoDB复制集(Replica Set)通过存储多份数据副本来保证数据的高可靠,通过自动的主备切换机制来保证服务的高可用。但需要注意的时,连接副本集的姿势如果不对,服务高可用将不复存在。
使用复制集时你需要知道的

MongoDB复制集里Primary节点是不固定的,当遇到复制集轮转升级、Primary宕机、网络分区等场景时,复制集可能会选举出一个新的Primary,而原来的Primary则会降级为Secondary,即发生主备切换。
总而言之,MongoDB复制集里Primary节点是不固定的,不固定的,不固定的,重要的事情说3遍。

当连接复制集时,如果直接指定Primary的地址来连接,当时可能可以正确读写数据的,但一旦复制集发生主备切换,你连接的Primary会降级为Secondary,你将无法继续执行写操作,这将严重影响到你的线上服务。
所以生产环境千万不要直连Primary,千万不要直连Primary,千万不要直连Primary。

说了这么多,到底该如何连接复制集?
正确连接复制集的姿势
要正确连接复制集,需要先了解下MongoDB的Connection String URI,所有官方的driver都支持以Connection String的方式来连接MongoDB。

下面就是Connection String包含的主要内容

mongodb://[username:password@]host1[:port1][,host2[:port2],…[,hostN[:portN]]][/[database][?options]]

mongodb:// 前缀,代表这是一个Connection String
username:password@ 如果启用了鉴权,需要指定用户密码
hostX:portX 复制集成员的ip:port信息,多个成员以逗号分割
/database 鉴权时,用户帐号所属的数据库
?options 指定额外的连接选项

以连接AliCloudDB for MongoDB为例,当你购买阿里云MongoDB复制集时,就会得到复制集的名称、以及复制集成员的地址信息。
为了方便用户使用,控制台上也生成了连接复制集的Connection String及通过Mongo Shell连接到命令。

例如通过java来连接,更多的DEMO

MongoClientURI connectionString = new MongoClientURI(“mongodb://root:xxxx@dds-bp114e3f1fc441342.mongodb.rds.aliyuncs.com:3717,dds-bp114e3f1fc441341.mongodb.rds.aliyuncs.com:3717/admin?replicaSet=mgset-677201”); // xxxx替换为root密码
MongoClient client = new MongoClient(connectionString);
MongoDatabase database = client.getDatabase(“mydb”);
MongoCollection collection = database.getCollection(“mycoll”);

通过正确的Connection String来连接MongoDB复制集时,客户端会自动检测复制集的主备关系,当主备关系发生变化时,自动将写切换到新的主上,以保证服务的高可用。
常用连接参数
如何实现读写分离?

在options里添加readPreference=secondaryPreferred即可实现,读请求优先到Secondary节点,从而实现读写分离的功能,更多读选项参考Read preferences
如何限制连接数?

在options里添加maxPoolSize=xx即可将客户端连接池限制在xx以内。
如何保证数据写入到大多数节点后才返回?

在options里添加w= majority即可保证写请求成功写入大多数节点才向客户端确认,更多写选项参考
Write Concern
https://docs.mongodb.com/manual/reference/write-concern/#write-concern

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值