欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2014年07月22日 10:08:51   投稿:hebedich  
mongodb的多服務(wù)器配置,以前寫過一篇文章,是master-slave模式的,master-slave模式,不能自動實現(xiàn)故障轉(zhuǎn)移和恢復(fù)。所以推薦大家使用mongodb的replica set,來實現(xiàn)多服務(wù)器的高性能。

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

一,三臺服務(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ù)庫目錄

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

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

[root@localhost ~]# cat /etc/mongodb.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //主服務(wù)器配置 
port = 27017  //監(jiān)聽端口 
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    //一個數(shù)據(jù)庫一個文件夾 
logappend=true     //追加方式寫日志 
replSet=repmore     //集群名稱,自定義 
oplogSize=1000     //oplog大小 
 
[root@localhost ~]# cat /etc/mongodb_2.conf |awk '{if($0 !~ /^$/ && $0 !~ /^#/) {print $0}}' //從服務(wù)器 
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}}' //從服務(wù)器 
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 

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

3,啟動三臺服務(wù)器

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

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

二,配置并初始化replica set
1,配置replica set節(jié)點

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

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

三,replica set主,從測試
1,主服務(wù)器測試

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

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

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

四,故障測試
前面我說過,mongodb replica set有故障轉(zhuǎn)移功能,下面就模擬一下,這個過程
1,故障轉(zhuǎn)移
1.1,關(guān)閉主服務(wù)器

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

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

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

replica set 故障測試
以前的從庫變主庫了,故障轉(zhuǎn)移成功

2,故障恢復(fù)

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

相關(guān)文章

  • centos8安裝MongoDB的詳細(xì)過程

    centos8安裝MongoDB的詳細(xì)過程

    MongoDB由MongoDB Inc開發(fā),并根據(jù)SSPL(服務(wù)器端公共許可證)進行分發(fā),是一個開源,跨平臺,面向文檔的數(shù)據(jù)庫管理系統(tǒng),本文重點給大家介紹centos8安裝MongoDB的詳細(xì)過程,感興趣的朋友一起看看吧
    2021-10-10
  • MongoDB實現(xiàn)查詢、分頁和排序操作以及游標(biāo)的使用

    MongoDB實現(xiàn)查詢、分頁和排序操作以及游標(biāo)的使用

    本文詳細(xì)講解了MongoDB實現(xiàn)查詢、分頁和排序操作以及游標(biāo)的使用方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • MongoDB副本集遷移實操案例詳解

    MongoDB副本集遷移實操案例詳解

    文中詳細(xì)闡述了通過全量?+?增量?Oplog?的遷移方式,完成一套副本集?MongoDB?遷移的全過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • 一次線上mongo慢查詢問題排查處理記錄

    一次線上mongo慢查詢問題排查處理記錄

    這篇文章主要給大家介紹了一次線上mongo慢查詢問題排查處理的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-03-03
  • mongodb 查看數(shù)據(jù)庫和表大小

    mongodb 查看數(shù)據(jù)庫和表大小

    mongodb查看數(shù)據(jù)庫和表的方法比較簡單,在為這里推薦使用stats的方法,直觀并且詳細(xì)。
    2014-07-07
  • MongoDB連接數(shù)據(jù)庫并創(chuàng)建數(shù)據(jù)等使用方法

    MongoDB連接數(shù)據(jù)庫并創(chuàng)建數(shù)據(jù)等使用方法

    MongoDB?是一個介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的。接下來通過本文給大家介紹MongoDB連接數(shù)據(jù)庫并創(chuàng)建數(shù)據(jù)等使用方法,感興趣的朋友一起看看吧
    2021-11-11
  • MongoDB使用mongoexport和mongoimport命令,批量導(dǎo)出和導(dǎo)入JSON數(shù)據(jù)到同一張表的實例

    MongoDB使用mongoexport和mongoimport命令,批量導(dǎo)出和導(dǎo)入JSON數(shù)據(jù)到同一張表的實例

    今天小編就為大家分享一篇關(guān)于MongoDB使用mongoexport和mongoimport命令,批量導(dǎo)出和導(dǎo)入JSON數(shù)據(jù)到同一張表的實例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • MongoDB系列教程(八):GridFS存儲詳解

    MongoDB系列教程(八):GridFS存儲詳解

    這篇文章主要介紹了MongoDB系列教程(八):GridFS存儲詳解,本文講解了什么是GridFS、GridFS的實現(xiàn)原理等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • mongodb與mysql命令詳細(xì)對比

    mongodb與mysql命令詳細(xì)對比

    MongoDB的好處挺多的,比如多列索引,查詢時可以用一些統(tǒng)計函數(shù),支持多條件查詢,但是目前多表查詢是不支持的,可以想辦法通過數(shù)據(jù)冗余來解決多表查詢的問題
    2013-08-08
  • MongoDB批量將時間戳轉(zhuǎn)為通用日期格式示例代碼

    MongoDB批量將時間戳轉(zhuǎn)為通用日期格式示例代碼

    這篇文章主要給大家介紹了關(guān)于MongoDB批量將時間戳轉(zhuǎn)為通用日期格式的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-07-07

最新評論