亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

mongodb replica set 配置高性能多服務器詳解

2020-10-29 18:53:40
字體:
來源:轉載
供稿:網友

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,創建數據庫目錄

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

在一臺機子上面模擬,三臺服務器,所以把DB目錄分開了。
2,創建配置文件

[root@localhost ~]# cat /etc/mongodb.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //主服務器配置 port = 27017  //監聽端口 fork = true   //后臺運行 pidfilepath = /var/run/mongodb/mongodb.pid //進程PID文件 logpath = /var/log/mongodb/mongodb.log  //日志文件 dbpath =/var/lib/mongodb   //db存放目錄 journal = true     //存儲模式 nohttpinterface = true   //禁用http directoryperdb=true    //一個數據庫一個文件夾 logappend=true     //追加方式寫日志 replSet=repmore     //集群名稱,自定義 oplogSize=1000     //oplog大小  [root@localhost ~]# cat /etc/mongodb_2.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //從服務器 port = 27018 fork = true pidfilepath = /var/run/mongodb/mongodb_2.pid logpath = /var/log/mongodb/mongodb_2.log dbpath =/var/lib/mongodb_2 journal = true nohttpinterface = true directoryperdb=true logappend=true replSet=repmore oplogSize=1000  [root@localhost ~]# cat /etc/mongodb_3.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //從服務器 port = 27019 fork = true pidfilepath = /var/run/mongodb/mongodb_3.pid logpath = /var/log/mongodb/mongodb_3.log dbpath =/var/lib/mongodb_3 journal = true nohttpinterface = true oplogSize = 1000 directoryperdb=true logappend=true replSet=repmore 

在這里要注意一點,不要把認證開起來了,不然查看rs.status();時,主從服務器間,無法連接,"lastHeartbeatMessage" : "initial sync couldn't connect to 127.0.0.1:27017"

3,啟動三臺服務器

mongod -f /etc/mongodb.conf mongod -f /etc/mongodb_2.conf mongod -f /etc/mongodb_3.conf 

注意:初次啟動時,主服務器比較快的,從服務器有點慢。

二,配置并初始化replica set
1,配置replica set節點

> 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

> rs.initiate(config); {  "info" : "Config now saved locally. Should come online in about a minute.",  "ok" : 1 } 

3,查看replica set各節點狀態

repmore:PRIMARY> rs.status(); {  "set" : "repmore",  "date" : ISODate("2013-12-16T21:01:51Z"),  "myState" : 2,  "syncingTo" : "127.0.0.1:27017",  "members" : [   {    "_id" : 0,    "name" : "127.0.0.1:27017",    "health" : 1,    "state" : 1,    "stateStr" : "PRIMARY",    "uptime" : 33,    "optime" : Timestamp(1387227638, 1),    "optimeDate" : ISODate("2013-12-16T21:00:38Z"),    "lastHeartbeat" : ISODate("2013-12-16T21:01:50Z"),    "lastHeartbeatRecv" : ISODate("2013-12-16T21:01:50Z"),    "pingMs" : 0,    "syncingTo" : "127.0.0.1:27018"   },   {    "_id" : 1,    "name" : "127.0.0.1:27018",    "health" : 1,    "state" : 2,    "stateStr" : "SECONDARY",    "uptime" : 1808,    "optime" : Timestamp(1387227638, 1),    "optimeDate" : ISODate("2013-12-16T21:00:38Z"),    "errmsg" : "syncing to: 127.0.0.1:27017",    "self" : true   },   {    "_id" : 2,    "name" : "127.0.0.1:27019",    "health" : 1,    "state" : 2,    "stateStr" : "SECONDARY",    "uptime" : 1806,    "optime" : Timestamp(1387227638, 1),    "optimeDate" : ISODate("2013-12-16T21:00:38Z"),    "lastHeartbeat" : ISODate("2013-12-16T21:01:50Z"),    "lastHeartbeatRecv" : ISODate("2013-12-16T21:01:51Z"),    "pingMs" : 0,    "lastHeartbeatMessage" : "syncing to: 127.0.0.1:27018",    "syncingTo" : "127.0.0.1:27018"   }  ],  "ok" : 1 } 

在這里要注意,rs.initiate初始化也是要一定時間的,剛執行完rs.initiate,我就查看狀態,從服務器的stateStr不是SECONDARY,而是stateStr" : "STARTUP2",等一會就好了。

三,replica set主,從測試
1,主服務器測試

repmore:PRIMARY> show dbs; local 1.078125GB repmore:PRIMARY> use test switched to db test repmore:PRIMARY> db.test.insert({'name':'tank','phone':'12345678'}); repmore:PRIMARY> db.test.find(); { "_id" : ObjectId("52af64549d2f9e75bc57cda7"), "name" : "tank", "phone" : "12345678" } 

 
2,從服務器測試

[root@localhost mongodb]# mongo 127.0.0.1:27018 //連接 MongoDB shell version: 2.4.6 connecting to: 127.0.0.1:27018/test repmore:SECONDARY> show dbs; local 1.078125GB test 0.203125GB repmore:SECONDARY> db.test.find();  //無權限查看 error: { "$err" : "not master and slaveOk=false", "code" : 13435 } repmore:SECONDARY> rs.slaveOk();  //從庫開啟 repmore:SECONDARY> db.test.find();  //從庫可看到主庫剛插入的數據 { "_id" : ObjectId("52af64549d2f9e75bc57cda7"), "name" : "tank", "phone" : "12345678" } repmore:SECONDARY> db.test.insert({'name':'zhangying','phone':'12345678'}); //從庫只讀,無插入權限 not master 

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

四,故障測試
前面我說過,mongodb replica set有故障轉移功能,下面就模擬一下,這個過程
1,故障轉移
1.1,關閉主服務器

[root@localhost mongodb]# ps aux |grep mongod //查看所有的mongod root  16977 0.2 1.1 3153692 44464 ?  Sl 04:31 0:02 mongod -f /etc/mongodb.conf root  17032 0.2 1.1 3128996 43640 ?  Sl 04:31 0:02 mongod -f /etc/mongodb_2.conf root  17092 0.2 0.9 3127976 38324 ?  Sl 04:31 0:02 mongod -f /etc/mongodb_3.conf root  20400 0.0 0.0 103248 860 pts/2 S+ 04:47 0:00 grep mongod [root@localhost mongodb]# kill 16977 //關閉主服務器進程 [root@localhost mongodb]# ps aux |grep mongod root  17032 0.2 1.1 3133124 43836 ?  Sl 04:31 0:02 mongod -f /etc/mongodb_2.conf root  17092 0.2 0.9 3127976 38404 ?  Sl 04:31 0:02 mongod -f /etc/mongodb_3.conf root  20488 0.0 0.0 103248 860 pts/2 S+ 04:47 0:00 grep mongod 

1.2,在主庫執行命令

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

1.3,從庫查看狀態,如下圖,

replica set 故障測試
以前的從庫變主庫了,故障轉移成功

2,故障恢復

mongod -f /etc/mongodb.conf 
啟動剛被關閉的主服務器,然后在登錄到主服務器,查看狀態rs.status();已恢復到最原始的狀態了。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕亚洲一区在线观看| 欧美日韩国产麻豆| 亚洲区一区二区| 亚洲精品久久久一区二区三区| 日韩美女在线看| 久久久亚洲国产天美传媒修理工| 久久天天躁狠狠躁夜夜躁2014| 日韩欧美精品网站| 国产欧美精品va在线观看| 最新国产精品拍自在线播放| 亚洲欧美一区二区三区四区| 国产999视频| 国产亚洲精品久久久久久777| 国产精品6699| 久久久精品999| 亚洲第一网中文字幕| 亚洲网站在线观看| 日韩va亚洲va欧洲va国产| 久久综合亚洲社区| 亚洲精品99999| 亚洲欧美精品一区二区| 亚洲天堂av图片| 欧美专区福利在线| 国产精品一区二区三区在线播放| 亚洲精品视频网上网址在线观看| 亚洲欧美一区二区三区久久| 久久琪琪电影院| 欧美日韩美女在线| 国语对白做受69| 亚洲精品一区中文| 精品久久久久久久中文字幕| 久久久久999| 在线看福利67194| 日韩精品视频免费在线观看| 国产亚洲成精品久久| 国产精品久久久久久一区二区| 国产精品91久久久久久| 欧美电影免费观看高清完整| 久久久国产在线视频| 精品国产精品自拍| 中文字幕久热精品视频在线| 欧美精品手机在线| 亚洲free性xxxx护士白浆| 黑人与娇小精品av专区| 精品少妇v888av| 色婷婷**av毛片一区| 欧美日韩国产黄| 狠狠做深爱婷婷久久综合一区| 国产精品入口免费视| 免费av在线一区| 日韩电影大全免费观看2023年上| 欧美激情视频免费观看| 久久影视三级福利片| 国产精品视频在线观看| 国产成人精品电影| 久热在线中文字幕色999舞| 国产日产欧美a一级在线| 在线观看日韩欧美| 成人网在线免费观看| 亚洲一区二区三区四区视频| 亚洲精品天天看| 欧美成人免费小视频| 57pao国产精品一区| 色哟哟入口国产精品| 一级做a爰片久久毛片美女图片| 亚洲国产另类久久精品| 久久免费高清视频| 国产视频久久久久| 亚洲欧美国产va在线影院| 亚洲精品国产综合区久久久久久久| 美女视频黄免费的亚洲男人天堂| 成人黄色影片在线| 精品爽片免费看久久| 国产精品白嫩美女在线观看| 热re99久久精品国产66热| 亚洲一级免费视频| 精品亚洲永久免费精品| 中文字幕久久久av一区| 国产欧美精品一区二区三区-老狼| 欧美性猛交xxxx久久久| 在线播放国产精品| 亚洲国产精久久久久久| 久久97久久97精品免视看| 亚洲欧美国产日韩中文字幕| 欧美寡妇偷汉性猛交| 欧美午夜女人视频在线| 成人福利网站在线观看| 精品国产一区二区三区久久久| 国产日韩av在线播放| 亚洲人精选亚洲人成在线| 欧美又大又硬又粗bbbbb| 精品在线观看国产| 亚洲黄色在线看| 91社影院在线观看| 91成人在线视频| 久久九九有精品国产23| 成人性生交大片免费观看嘿嘿视频| 丝袜美腿精品国产二区| 一本大道香蕉久在线播放29| 91精品国产综合久久香蕉最新版| 欧美激情区在线播放| 国产精品久久久久久久久久东京| 精品一区二区电影| 久久色在线播放| 国产成人一区二区三区| 欧美综合在线观看| 国产精品久久久av| 一本久久综合亚洲鲁鲁| 麻豆乱码国产一区二区三区| 精品久久久久久久久中文字幕| 欧美日韩在线视频一区二区| 国语自产精品视频在线看抢先版图片| 欧美乱大交做爰xxxⅹ性3| 91精品在线影院| 亚洲人成在线播放| 欧美黑人国产人伦爽爽爽| 日韩大陆欧美高清视频区| 日韩在线视频导航| 成人激情视频网| 国产欧亚日韩视频| 欧美自拍视频在线观看| 国产亚洲美女精品久久久| 欧美激情一区二区久久久| 18久久久久久| 欧美性xxxx极品高清hd直播| 在线看欧美日韩| 亚洲国模精品私拍| 久久九九有精品国产23| 91系列在线播放| 亚洲天堂男人的天堂| 国产精品久久久久久婷婷天堂| 九九热99久久久国产盗摄| 4p变态网欧美系列| 夜夜狂射影院欧美极品| 7777kkkk成人观看| 欧美自拍视频在线| 欧洲美女7788成人免费视频| 亚洲国产精品va| 国产精品日韩在线一区| 中日韩美女免费视频网站在线观看| 日本精品性网站在线观看| 日韩av黄色在线观看| 国产精品白嫩初高中害羞小美女| 国产精品劲爆视频| 亚洲a成v人在线观看| 久久国产天堂福利天堂| 成人中文字幕+乱码+中文字幕| 久久久久久久成人| 国产免费观看久久黄| 亚洲一区二区三区成人在线视频精品| 亚洲精品资源在线| 中文字幕亚洲一区二区三区| 精品激情国产视频| 日韩亚洲国产中文字幕| 久久精品国产2020观看福利| 日韩性xxxx爱| 欧美黑人巨大精品一区二区| 91精品视频在线免费观看| 久久精品99久久久久久久久| 国产美女被下药99| 欧美大片在线看| 久久久在线观看| 热久久美女精品天天吊色| 亚洲女性裸体视频|