此文已由作者袁欢授权网易云社区发布。

欢迎访问网易云社区,了解更多网易技术产品运营经验。

部署方式
在3台centos6.6系统上以Replica Set方式部署mongodb3.0.2集群。

官方参考资料:

http://docs.mongodb.org/manual/tutorial/deploy-replica-set/

http://docs.mongodb.org/manual/tutorial/install-mongodb-on-red-hat/

集群的IP地址分配
# node01: 192.168.35.173(PRIMARY node)
# node02: 192.168.35.96(SECONDARY node)
# node03: 192.168.35.174(SECONDARY node)

# 添加mongodb的yum源(所有节点)

echo "[mongodb-org-3.0]" > /etc/yum.repos.d/mongodb-org-3.0.repo
echo "name=MongoDB Repository" >> /etc/yum.repos.d/mongodb-org-3.0.repo
echo "baseurl=http://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.0/x86_64/" >> /etc/yum.repos.d/mongodb-org-3.0.repo
echo "gpgcheck=0" >> /etc/yum.repos.d/mongodb-org-3.0.repo
echo "enabled=1" >> /etc/yum.repos.d/mongodb-org-3.0.repo

# yum安装mongodb(所有节点)

yum install -y mongodb-org-3.0.2 mongodb-org-server-3.0.2 mongodb-org-shell-3.0.2 mongodb-org-mongos-3.0.2 mongodb-org-tools-3.0.2
mkdir -p /data/db && chown -R mongod.mongod /data/

# 修改主机名和hosts文件(所有节点)

# vim /etc/sysconfig/network
# sysctl kernel.hostname=node0001.nemongo.com
# sysctl kernel.hostname=node0002.nemongo.com
# sysctl kernel.hostname=node0003.nemongo.com

echo "192.168.35.173 node0001.nemongo.com" >> /etc/hosts
echo "192.168.35.96 node0002.nemongo.com" >> /etc/hosts
echo "192.168.35.174 node0003.nemongo.com" >> /etc/hosts

# 修改mongodb的配置文件(所有节点)

sed -i 's/bind_ip=127.0.0.1/#bind_ip=127.0.0.1/g' /etc/mongod.conf
sed -i 's/#replSet=setname/replSet=ne_aws_01/g' /etc/mongod.conf

# 启动mongodb(所有节点)

service mongod start

# 在mongodb主节点上配置集群(PRIMARY 节点)

mongo
> rs.initiate() # 只有node0001上面需要执行rs.initiate()
> rs.conf()
> rs.add("node0002.nemongo.com") # node0002上面不要执行rs.initiate(),否则无法添加
> rs.add("node0003.nemongo.com") # node0003上面不要执行rs.initiate(),否则无法添加
> rs.status() # 每个节点上都可以查看集群状态

> rs.initiate()

{

"info2" : "no configuration explicitly specified -- making one",

"me" : "node0001.nemongo.com:27017",

"ok" : 0,

"errmsg" : "No host described in new configuration 1 for replica set ne_aws_01 maps to this node",

"code" : 93

}

ne_aws_01:PRIMARY> rs.add("node0002.nemongo.com:27017")

{ "ok" : 1 }

ne_aws_01:PRIMARY> rs.add("node0003.nemongo.com")

{ "ok" : 1 }

ne_aws_01:PRIMARY> rs.status()

{

"set" : "ne_aws_01",

"date" : ISODate("2015-05-08T04:49:30.768Z"),

"myState" : 1,

"members" : [

{

"_id" : 0,

"name" : "node0001.nemongo.com:27017",

"health" : 1,

"state" : 1,

"stateStr" : "PRIMARY",

"uptime" : 1471,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"electionTime" : Timestamp(1431059099, 1),

"electionDate" : ISODate("2015-05-08T04:24:59Z"),

"configVersion" : 3,

"self" : true

},

{

"_id" : 1,

"name" : "node0002.nemongo.com:27017",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 192,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"lastHeartbeat" : ISODate("2015-05-08T04:49:29.756Z"),

"lastHeartbeatRecv" : ISODate("2015-05-08T04:49:30.263Z"),

"pingMs" : 1,

"configVersion" : 3

},

{

"_id" : 2,

"name" : "node0003.nemongo.com:27017",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 187,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"lastHeartbeat" : ISODate("2015-05-08T04:49:29.756Z"),

"lastHeartbeatRecv" : ISODate("2015-05-08T04:49:29.795Z"),

"pingMs" : 1,

"lastHeartbeatMessage" : "could not find member to sync from",

"configVersion" : 3

}

],

"ok" : 1

}

将mongodb主节点停掉:service mongod stop,这时候mongodb集群将会重新选举产生新的primary节点,在node0002上查看集群状态:

ne_aws_01:PRIMARY> rs.status()

{

"set" : "ne_aws_01",

"date" : ISODate("2015-05-08T04:51:13.359Z"),

"myState" : 1,

"members" : [

{

"_id" : 0,

"name" : "node0001.nemongo.com:27017",

"health" : 0,

"state" : 8,

"stateStr" : "(not reachable/healthy)",

"uptime" : 0,

"optime" : Timestamp(0, 0),

"optimeDate" : ISODate("1970-01-01T00:00:00Z"),

"lastHeartbeat" : ISODate("2015-05-08T04:51:11.361Z"),

"lastHeartbeatRecv" : ISODate("2015-05-08T04:51:11.951Z"),

"pingMs" : 1,

"lastHeartbeatMessage" : "Failed attempt to connect to node0001.nemongo.com:27017; couldn't connect to server node0001.nemongo.com:27017 (192.168.35.173), connection attempt failed",

"configVersion" : -1

},

{

"_id" : 1,

"name" : "node0002.nemongo.com:27017",

"health" : 1,

"state" : 1,

"stateStr" : "PRIMARY",

"uptime" : 364,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"electionTime" : Timestamp(1431060617, 1),

"electionDate" : ISODate("2015-05-08T04:50:17Z"),

"configVersion" : 3,

"self" : true

},

{

"_id" : 2,

"name" : "node0003.nemongo.com:27017",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 284,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"lastHeartbeat" : ISODate("2015-05-08T04:51:13.159Z"),

"lastHeartbeatRecv" : ISODate("2015-05-08T04:51:12.703Z"),

"pingMs" : 1,

"configVersion" : 3

}

],

"ok" : 1

}

将node0001重新启动:service mongod start,再次查看mongodb集群状态,就会发现node0001变成了SECONDARY节点:

ne_aws_01:SECONDARY> rs.status()

{

"set" : "ne_aws_01",

"date" : ISODate("2015-05-08T04:53:54.550Z"),

"myState" : 2,

"members" : [

{

"_id" : 0,

"name" : "node0001.nemongo.com:27017",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 168,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"configVersion" : 3,

"self" : true

},

{

"_id" : 1,

"name" : "node0002.nemongo.com:27017",

"health" : 1,

"state" : 1,

"stateStr" : "PRIMARY",

"uptime" : 167,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"lastHeartbeat" : ISODate("2015-05-08T04:53:53.474Z"),

"lastHeartbeatRecv" : ISODate("2015-05-08T04:53:52.881Z"),

"pingMs" : 1,

"electionTime" : Timestamp(1431060617, 1),

"electionDate" : ISODate("2015-05-08T04:50:17Z"),

"configVersion" : 3

},

{

"_id" : 2,

"name" : "node0003.nemongo.com:27017",

"health" : 1,

"state" : 2,

"stateStr" : "SECONDARY",

"uptime" : 167,

"optime" : Timestamp(1431060383, 1),

"optimeDate" : ISODate("2015-05-08T04:46:23Z"),

"lastHeartbeat" : ISODate("2015-05-08T04:53:53.474Z"),

"lastHeartbeatRecv" : ISODate("2015-05-08T04:53:54.382Z"),

"pingMs" : 1,

"configVersion" : 3

}

],

"ok" : 1

}

免费体验云安全(易盾)内容安全、验证码等服务

更多网易技术、产品、运营经验分享请点击

相关文章:
【推荐】 知物由学|AI网络安全实战:生成对抗网络
【推荐】 kubernetes大概的工作原理
【推荐】 OC静态代码检查实战

在CentOS6.6上以replSet方式部署MongoDB集群的更多相关文章

  1. 基于已有集群动态发现方式部署 Etcd 集群

    etcd提供了多种部署集群的方式,在「通过静态发现方式部署etcd集群」 一文中我们介绍了如何通过静态发现方式部署集群. 不过很多时候,你只知道你要搭建一个多大(包含多少节点)的集群,但是并不能事先知 ...

  2. 基于 DNS 动态发现方式部署 Etcd 集群

    使用discovery的方式来搭建etcd集群方式有两种:etcd discovery和DNS discovery.在 「基于已有集群动态发现方式部署etcd集群」一文中讲解了etcd discove ...

  3. 在Docker中安装和部署MongoDB集群

    此文已由作者袁欢授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 在Docker中安装mongodb 采用的mongodb镜像:https://registry.hub.doc ...

  4. centos7下安装部署mongodb集群(副本集模式)

    环境需求:Mongodb集群有三种模式:  Replica Set, Sharding,Master-Slaver.  这里部署的是Replica Set模式. 测试环境: 这里副本集(Replica ...

  5. 通过静态发现方式部署 Etcd 集群

    在「etcd使用入门」一文中对etcd的基本知识点和安装做了一个简要的介绍,这次我们来说说如何部署一个etcd集群. etcd构建自身高可用集群主要有三种形式: 静态发现: 预先已知etcd集群中有哪 ...

  6. 一键部署MongoDB集群Windows版

    由于周末在家手头没有虚拟机,所以在windows下单机完毕部署要求,并编写bat执行脚本. 1.创建配置文件及相关文件夹 总的启动脚本例如以下(startmc.bat): rem m1 start m ...

  7. CentOS6.8部署MongoDB集群及支持auth认证

    三个节点的副本集如下图所示: 实验目的: 配置MongoDB的3节点副本集 3个节点的副本集都要开启auth认证,并且开启认证后,能互相通信 第一步 - 准备环境 准备三个虚拟机,其中一个用作Prim ...

  8. 用配置文件方式启动mongodb集群

  9. centos6.5环境基于conga的web图形化界面方式配置rhcs集群

    一.简介 RHCS 即 RedHat Cluster Suite ,中文意思即红帽集群套件.红帽集群套件(RedHat Cluter Suite, RHCS)是一套综合的软件组件,可以通过在部署时采用 ...

随机推荐

  1. URL 截取参数 正则

    用处很多,记录下. function getvl(name) { var reg = new RegExp("(^|\\?|&)"+ name +"=([^&am ...

  2. canvas转盘抽奖的实现(二)

    本篇是<canvas转盘抽奖的实现(一)>的另一种实现方法,主要通过css3的transform以及transition过渡来实现.     // ' + r + '等奖'; } draw ...

  3. windows下gVim 中文显示为乱码

    打开vimrc文件,在vim的安装目录下可以找到该文件: 或在windows下是在vim/gvim下输入:edit $vim/_vimrc. 在文件的末尾添加一句 "set fileenco ...

  4. JNI在C和C++中的调用区别

    C-style JNI looks like (*env)->SomeJNICall(env, param1 ...) C++ style JNI looks like env->Some ...

  5. 2016/08/11 Thinkphp之getField用法总结

    getField方法是ThinkPHP中用来获取字段值的方法,区别于select和find方法,通常仅用于获取个别字段的值.但是事实上并没有那么简单,该方法的用法总结如下: 获取某个字段值 这个是ge ...

  6. Error:Execution failed for task ':app:clean'. > Unable to delete directory: ***/app/build/generated/***

    第一次从svn拉下来的工程,在clean的时候会出现 Error:Execution failed for task ':app:clean'. > Unable to delete direc ...

  7. HTML5 Canvas 画图入门

    HTML5 Canvas 画图入门 HTML5 Canvas 画图入门,仅供学习參考 <!DOCTYPE html> <html> <head> <meta ...

  8. linux source命令与sh shell scripts的区别

    source FileName 作用:在当前bash环境下读取并执行FileName中的命令. 注:该命令通常用命令“.”来替代. 如:source .bash_rc 与 . .bash_rc 是等效 ...

  9. Struts action

    <action name="KnowledgeBankManageAction_*" class="knowledgeBankManageAction" ...

  10. 最优配对问题(集合上的动态规划) —— 状压DP

    题目来源:紫书P284 题意: 给出n个点的空间坐标(n为偶数, n<=20), 把他们配成n/2对, 问:怎样配对才能使点对的距离和最小? 题解: 设dp[s]为:状态为s(s代表着某个子集) ...