mongodb replica set 多服务器 高可用 配置 详解

来源:互联网 发布:网络主播是一种病态 编辑:程序博客网 时间:2024/04/28 22:34

mongodb的多服务器配置,以前写过一篇文章,是master-slave模式的,请参考:mongodb 主从 配置 详解。master-slave模式,不能自动实现故障转移和恢复。所以推荐大家使用mongodb的replica set,来实现多服务器的高可用。给我的感觉是replica set好像自带了heartbeat功能,挺强大的。

一,三台服务器,1主,2从

服务器1:127.0.0.1:27017

服务器2:127.0.0.1:27018

服务器3:127.0.0.1:27019

1,创建数据库目录

查看复制打印?
  1. [root@localhost ~]# mkdir /var/lib/{mongodb_2,mongodb_3}  

在一台机子上面模拟,三台服务器,所以把DB目录分开了。

2,创建配置文件

查看复制打印?
  1. [root@localhost ~]# cat /etc/mongodb.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'  //主服务器配置  
  2. port = 27017        //监听端口  
  3. fork = true         //后台运行  
  4. pidfilepath = /var/run/mongodb/mongodb.pid    //进程PID文件  
  5. logpath = /var/log/mongodb/mongodb.log        //日志文件  
  6. dbpath =/var/lib/mongodb           //db存放目录  
  7. journal = true                   //存储模式  
  8. nohttpinterface = true           //禁用http  
  9. directoryperdb=true              //一个数据库一个文件夹  
  10. logappend=true                  //追加方式写日志  
  11. replSet=repmore                 //集群名称,自定义  
  12. oplogSize=1000                  //oplog大小  
  13.   
  14. [root@localhost ~]# cat /etc/mongodb_2.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'  //从服务器  
  15. port = 27018  
  16. fork = true  
  17. pidfilepath = /var/run/mongodb/mongodb_2.pid  
  18. logpath = /var/log/mongodb/mongodb_2.log  
  19. dbpath =/var/lib/mongodb_2  
  20. journal = true  
  21. nohttpinterface = true  
  22. directoryperdb=true  
  23. logappend=true  
  24. replSet=repmore  
  25. oplogSize=1000  
  26.   
  27. [root@localhost ~]# cat /etc/mongodb_3.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}'  //从服务器  
  28. port = 27019  
  29. fork = true  
  30. pidfilepath = /var/run/mongodb/mongodb_3.pid  
  31. logpath = /var/log/mongodb/mongodb_3.log  
  32. dbpath =/var/lib/mongodb_3  
  33. journal = true  
  34. nohttpinterface = true  
  35. oplogSize = 1000  
  36. directoryperdb=true  
  37. logappend=true  
  38. replSet=repmore  

在这里要注意一点,不要把认证开起来了,不然查看rs.status();时,主从服务器间,无法连接,"lastHeartbeatMessage" : "initial sync couldn't connect to 127.0.0.1:27017"

3,启动三台服务器

  1. mongod -f /etc/mongodb.conf  
  2. mongod -f /etc/mongodb_2.conf  
  3. mongod -f /etc/mongodb_3.conf  

注意:初次启动时,主服务器比较快的,从服务器有点慢。

二,配置并初始化replica set

1,配置replica set节点

查看复制打印?
  1. > config = {_id:"repmore",members:[{_id:0,host:'127.0.0.1:27017',priority :2},{_id:1,host:'127.0.0.1:27018',priority:1},{_id:2,host:'127.0.0.1:27019',priority:1}]}  

2,初始化replica set

查看复制打印?
  1. > rs.initiate(config);  
  2. {  
  3.     "info" : "Config now saved locally.  Should come online in about a minute.",  
  4.     "ok" : 1  
  5. }  

3,查看replica set各节点状态

查看复制打印?
  1. repmore:PRIMARY> rs.status();  
  2. {  
  3.     "set" : "repmore",  
  4.     "date" : ISODate("2013-12-16T21:01:51Z"),  
  5.     "myState" : 2,  
  6.     "syncingTo" : "127.0.0.1:27017",  
  7.     "members" : [  
  8.         {  
  9.             "_id" : 0,  
  10.             "name" : "127.0.0.1:27017",  
  11.             "health" : 1,  
  12.             "state" : 1,  
  13.             "stateStr" : "PRIMARY",  
  14.             "uptime" : 33,  
  15.             "optime" : Timestamp(1387227638, 1),  
  16.             "optimeDate" : ISODate("2013-12-16T21:00:38Z"),  
  17.             "lastHeartbeat" : ISODate("2013-12-16T21:01:50Z"),  
  18.             "lastHeartbeatRecv" : ISODate("2013-12-16T21:01:50Z"),  
  19.             "pingMs" : 0,  
  20.             "syncingTo" : "127.0.0.1:27018"  
  21.         },  
  22.         {  
  23.             "_id" : 1,  
  24.             "name" : "127.0.0.1:27018",  
  25.             "health" : 1,  
  26.             "state" : 2,  
  27.             "stateStr" : "SECONDARY",  
  28.             "uptime" : 1808,  
  29.             "optime" : Timestamp(1387227638, 1),  
  30.             "optimeDate" : ISODate("2013-12-16T21:00:38Z"),  
  31.             "errmsg" : "syncing to: 127.0.0.1:27017",  
  32.             "self" : true  
  33.         },  
  34.         {  
  35.             "_id" : 2,  
  36.             "name" : "127.0.0.1:27019",  
  37.             "health" : 1,  
  38.             "state" : 2,  
  39.             "stateStr" : "SECONDARY",  
  40.             "uptime" : 1806,  
  41.             "optime" : Timestamp(1387227638, 1),  
  42.             "optimeDate" : ISODate("2013-12-16T21:00:38Z"),  
  43.             "lastHeartbeat" : ISODate("2013-12-16T21:01:50Z"),  
  44.             "lastHeartbeatRecv" : ISODate("2013-12-16T21:01:51Z"),  
  45.             "pingMs" : 0,  
  46.             "lastHeartbeatMessage" : "syncing to: 127.0.0.1:27018",  
  47.             "syncingTo" : "127.0.0.1:27018"  
  48.         }  
  49.     ],  
  50.     "ok" : 1  
  51. }  

在这里要注意,rs.initiate初始化也是要一定时间的,刚执行完rs.initiate,我就查看状态,从服务器的stateStr不是SECONDARY,而是stateStr" : "STARTUP2",等一会就好了。

三,replica set主,从测试

1,主服务器测试

查看复制打印?
  1. repmore:PRIMARY> show dbs;  
  2. local    1.078125GB  
  3. repmore:PRIMARY> use test  
  4. switched to db test  
  5. repmore:PRIMARY> db.test.insert({'name':'tank','phone':'12345678'});  
  6. repmore:PRIMARY> db.test.find();  
  7. "_id" : ObjectId("52af64549d2f9e75bc57cda7"), "name" : "tank""phone" : "12345678" }  

2,从服务器测试

查看复制打印?
  1. [root@localhost mongodb]# mongo 127.0.0.1:27018   //连接  
  2. MongoDB shell version: 2.4.6  
  3. connecting to: 127.0.0.1:27018/test  
  4. repmore:SECONDARY> show dbs;  
  5. local    1.078125GB  
  6. test    0.203125GB  
  7. repmore:SECONDARY> db.test.find();     //无权限查看  
  8. error: { "$err" : "not master and slaveOk=false""code" : 13435 }  
  9. repmore:SECONDARY> rs.slaveOk();       //从库开启  
  10. repmore:SECONDARY> db.test.find();     //从库可看到主库刚插入的数据  
  11. "_id" : ObjectId("52af64549d2f9e75bc57cda7"), "name" : "tank""phone" : "12345678" }  
  12. repmore:SECONDARY> db.test.insert({'name':'zhangying','phone':'12345678'});   //从库只读,无插入权限  
  13. not master  

到这儿,我们的replica set就配置好了。

四,故障测试

前面我说过,mongodb replica set有故障转移功能,下面就模拟一下,这个过程

1,故障转移

1.1,关闭主服务器

查看复制打印?
  1. [root@localhost mongodb]# ps aux |grep mongod    //查看所有的mongod  
  2. root     16977  0.2  1.1 3153692 44464 ?       Sl   04:31   0:02 mongod -f /etc/mongodb.conf  
  3. root     17032  0.2  1.1 3128996 43640 ?       Sl   04:31   0:02 mongod -f /etc/mongodb_2.conf  
  4. root     17092  0.2  0.9 3127976 38324 ?       Sl   04:31   0:02 mongod -f /etc/mongodb_3.conf  
  5. root     20400  0.0  0.0 103248   860 pts/2    S+   04:47   0:00 grep mongod  
  6. [root@localhost mongodb]# kill 16977  //关闭主服务器进程  
  7. [root@localhost mongodb]# ps aux |grep mongod  
  8. root     17032  0.2  1.1 3133124 43836 ?       Sl   04:31   0:02 mongod -f /etc/mongodb_2.conf  
  9. root     17092  0.2  0.9 3127976 38404 ?       Sl   04:31   0:02 mongod -f /etc/mongodb_3.conf  
  10. root     20488  0.0  0.0 103248   860 pts/2    S+   04:47   0:00 grep mongod  

1.2,在主库执行命令

  1. repmore:PRIMARY> show dbs;  
  2. Tue Dec 17 04:48:02.392 DBClientCursor::init call() failed  

1.3,从库查看状态,如下图,

replica set 故障测试

replica set 故障测试

以前的从库变主库了,故障转移成功

2,故障恢复

  1. mongod -f /etc/mongodb.conf  

启动刚被关闭的主服务器,然后在登录到主服务器,查看状态rs.status();已恢复到最原始的状态了。

0 0
原创粉丝点击