麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 數(shù)據(jù)庫(kù) > MongoDB > 正文

mongodb replica set 配置高性能多服務(wù)器詳解

2020-03-14 13:25:50
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

mongodb的多服務(wù)器配置,以前寫過(guò)一篇文章,是master-slave模式的,master-slave模式,不能自動(dòng)實(shí)現(xiàn)故障轉(zhuǎn)移和恢復(fù)。所以推薦大家使用mongodb的replica set,來(lái)實(shí)現(xiàn)多服務(wù)器的高性能。

mongodb的多服務(wù)器配置,以前寫過(guò)一篇文章,是master-slave模式的,請(qǐng)參考:詳解mongodb 主從配置。master-slave模式,不能自動(dòng)實(shí)現(xiàn)故障轉(zhuǎn)移和恢復(fù)。所以推薦大家使用mongodb的replica set,來(lái)實(shí)現(xiàn)多服務(wù)器的高可用。給我的感覺是replica set好像自帶了heartbeat功能,挺強(qiáng)大的。

一,三臺(tái)服務(wù)器,1主,2從

服務(wù)器1:127.0.0.1:27017

服務(wù)器2:127.0.0.1:27018

服務(wù)器3:127.0.0.1:27019

1,創(chuàng)建數(shù)據(jù)庫(kù)目錄

  1. [root@localhost ~]# mkdir /var/lib/{mongodb_2,mongodb_3} 

在一臺(tái)機(jī)子上面模擬,三臺(tái)服務(wù)器,所以把DB目錄分開了。

2,創(chuàng)建配置文件

  1. [root@localhost ~]# cat /etc/mongodb.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //主服務(wù)器配置  
  2. port = 27017 //監(jiān)聽端口  
  3. fork = true //后臺(tái)運(yùn)行  
  4. pidfilepath = /var/run/mongodb/mongodb.pid //進(jìn)程PID文件  
  5. logpath = /var/log/mongodb/mongodb.log //日志文件  
  6. dbpath =/var/lib/mongodb //db存放目錄  
  7. journal = true //存儲(chǔ)模式  
  8. nohttpinterface = true //禁用http  
  9. directoryperdb=true //一個(gè)數(shù)據(jù)庫(kù)一個(gè)文件夾  
  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}}' //從服務(wù)器  
  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}}' //從服務(wù)器  
  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  


在這里要注意一點(diǎn),不要把認(rèn)證開起來(lái)了,不然查看rs.status();時(shí),主從服務(wù)器間,無(wú)法連接,"lastHeartbeatMessage" : "initial sync couldn't connect to 127.0.0.1:27017"

3,啟動(dòng)三臺(tái)服務(wù)器

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


注意:初次啟動(dòng)時(shí),主服務(wù)器比較快的,從服務(wù)器有點(diǎn)慢。

二,配置并初始化replica set

1,配置replica set節(jié)點(diǎn)

  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各節(jié)點(diǎn)狀態(tài)

  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初始化也是要一定時(shí)間的,剛執(zhí)行完rs.initiate,我就查看狀態(tài),從服務(wù)器的stateStr不是SECONDARY,而是stateStr" : "STARTUP2",等一會(huì)就好了。

三,replica set主,從測(cè)試

1,主服務(wù)器測(cè)試

  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,從服務(wù)器測(cè)試

  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(); //無(wú)權(quán)限查看  
  8. error: { "$err" : "not master and slaveOk=false""code" : 13435 }  
  9. repmore:SECONDARY> rs.slaveOk(); //從庫(kù)開啟  
  10. repmore:SECONDARY> db.test.find(); //從庫(kù)可看到主庫(kù)剛插入的數(shù)據(jù)  
  11. "_id" : ObjectId("52af64549d2f9e75bc57cda7"), "name" : "tank""phone" : "12345678" }  
  12. repmore:SECONDARY> db.test.insert({'name':'zhangying','phone':'12345678'}); //從庫(kù)只讀,無(wú)插入權(quán)限  
  13. not master  


到這兒,我們的replica set就配置好了。

四,故障測(cè)試

前面我說(shuō)過(guò),mongodb replica set有故障轉(zhuǎn)移功能,下面就模擬一下,這個(gè)過(guò)程

1,故障轉(zhuǎn)移

1.1,關(guān)閉主服務(wù)器

  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 //關(guān)閉主服務(wù)器進(jìn)程  
  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,在主庫(kù)執(zhí)行命令

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


1.3,從庫(kù)查看狀態(tài),如下圖,

mongodb replica set 配置高性能多服務(wù)器詳解

replica set 故障測(cè)試

以前的從庫(kù)變主庫(kù)了,故障轉(zhuǎn)移成功

2,故障恢復(fù)

mongod -f /etc/mongodb.conf

啟動(dòng)剛被關(guān)閉的主服務(wù)器,然后在登錄到主服務(wù)器,查看狀態(tài)rs.status();已恢復(fù)到最原始的狀態(tài)了。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美日韩在线视频观看 | av在线免费观看播放 | 亚洲欧美一区二区三区在线观看 | 久久99精品久久久久久小说 | 国产日韩a | 久久久国产电影 | 斗破苍穹在线观看免费完整观看 | 国内精品久久久久久久星辰影视 | 黄色片在线观看网站 | 欧美1—12sexvideos | 一级做a爱片久久毛片a高清 | 欧美精品一级片 | 午夜精品久久久久久中宇 | 逼特逼视频在线观看 | 国产精选电影免费在线观看网站 | 热re91久久精品国产99热 | 日本道中文字幕 | 国产污污视频 | 日日噜噜噜夜夜狠狠久久蜜桃 | 国产午夜精品久久久久婷 | 国内精品国产三级国产a久久 | 99riav国产在线观看 | av成人在线电影 | 欧美1区2区在线观看 | 在线播放亚洲精品 | 国产男女 爽爽爽爽视频 | 亚洲第五色综合网 | 久久久久久久久久91 | xxxxxx性 | 中文字幕一区久久 | 久久av喷吹av高潮av懂色 | 欧美18—19sex性hd按摩 | 美女黄色毛片免费看 | 一区二区三区精品国产 | 免费视频a | 一级大片视频 | 久久久久久久午夜 | 国产三级a三级三级 | 91精品国产综合久久婷婷香 | 黄污污网站 | 国产精品久久久久久久久久久久久久久 |