设为首页 收藏本站
查看: 1303|回复: 0

[经验分享] mongodb replica set 副本集 安装部署(三)

[复制链接]

尚未签到

发表于 2018-10-27 12:36:12 | 显示全部楼层 |阅读模式
1.节点类型  简单的说副本集(replica set)就是有自动故障恢复功能的主从集群,主从集群和副本集最为明显的区别就是副本集没有固定的主节点,整个集群会选举出一个主节点。
  节点类型
  standard:常规节点,它存储一份完整的数据副本,参与选举投票,有可能成为primary节点。
  passive:存储了完整的数据副本,参与投票,不能成为primary节点。
  arbiter:仲裁节点,只参与投票,不接收复制的数据,也不能成为primary节点。
  一个repica sets节点数量最好为奇数(odd)。
  实验是三个节点:
  两个standard节点(这两个节点直接可以互切primary secondary)。
  一个arbiter节点,它手中握着一张选票,决定上面两个standard节点中的哪一个可以成为primay。
  2.
  relica sets 集群三节点分布
  实验是三个节点:
  两个standard节点(这两个节点直接可以互切primary secondary)。
  node1ip:192.168.137.12
  node2ip:192.168.137.13
  一个arbiter节点,它手中握着一张选票,决定上面两个standard节点中的哪一个可以成为primay。
  node3ip:192.168.137.14
  3.配置步骤
  启动第一个standard节点
  /usr/local/mongodb/bin/mongod --port 27017 --dbpath /data/mongodb/db1/ --logpath /data/mongodb/logs/m1.log --logappend --replSet test/192.168.137.13:27017  --maxConns=200 --fork
  启动第二个standard节点
  /usr/local/mongodb/bin/mongod --port 27017 --dbpath /data/mongodb/db1/ --logpath /data/mongodb/logs/m1.log --logappend --replSet test/192.168.137.12:27017  --maxConns=200 --fork
  启动第三个arbiter节点
  /usr/local/mongodb/bin/mongod --port 27017 --dbpath /data/mongodb/db1/ --logpath /data/mongodb/logs/m1.log --logappend --replSet test/192.168.137.13:27017,192.168.137.12:27017  --maxConns=200 --fork
  以上配置完成后再任意一个standard节点运行mongo
  > use admin
  > cfg={_id:'test',members:[
  ...{_id:0,host:'192.168.137.12:27017'},
  ...{_id:1,host:'192.168.137.13:27017'}]
  ...}
  出现下面的提示信息就代表成功了
  "info" : "Config now saved locally.  Should come online in about a minute.",
  "ok" : 1
  然后再加入arbiter节点
  PRIMARY> rs.addArb("192.168.137.14:27017");
  到了这里,这个集群已经配置完成,三个节点的角色已经分配完毕,怎么查看是否正常呢
  rs.status()通过这个命令,可以查看各个节点的ip、角色已经是否正常
  可以查看replica set的状态,包括名称,时间,当前登录的mongod是primary还是secondary,以及成员的信息等。
  在replica set的信息中,其中重要的是:
  myState的值,如果是1代表当前登录的是primary;如果是2代表当前登录的是secondary。
  成员信息中包括地址,健康状态,是primary还是secondary等。
  成员信息中比较重要的是
  state:1表示该host是当前可以进行读写,2:不能读写
  health:1表示该host目前是正常的,0:异常
  4.mongodb replica sets 的管理
  添加普通数据节点
  PRIMARY> rs.add("ip:port")
  删除节点
  PRIMARY> rs.remove("ip:port")
  显示当前谁是primay
  PRIMARY> rs.isMaster()
  将一个普通数据节点修改为passive节点,也就是能同步数据、投票,但是不能成为primay。
  除了仲裁节点,其他每个节点都有个优先权,我们可以通过设置优先权来决定谁的成为primay的权重最大。
  MongoDB replica sets中通过设置priority的值来决定优先权的大小,这个值的范围是0--100,值越大,优先权越高。
  如果值是0,那么不能成为primay。
  通过rs.conf()命令查看出节点列表
  将node2节点的priority值修改成0,让它只接收数据,不参与成为primary的竞争。在PRIMARY节点上操作:
  cfg = rs.conf()
  cfg.members[1].priority = 0
  rs.reconfig(cfg)



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-627129-1-1.html 上篇帖子: MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB数据 下篇帖子: 使用Fluentd + MongoDB构建实时日志收集系统
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表