本文主要记录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:[email protected]: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