成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

MongoDBReplicaSet部署

在生產(chǎn)中使用MongoDB, 為了數(shù)據(jù)安全性和訪問(wèn)穩(wěn)定性. 副本集是經(jīng)常被使用到的.

公司主營(yíng)業(yè)務(wù):成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)推出荊州免費(fèi)做網(wǎng)站回饋大家。

書接上回, 話說(shuō)MongoDB副本集已經(jīng)安裝過(guò)很多次了.但是每次都要去 百度 具體命令細(xì)節(jié).

只好自己整理筆記,記錄下來(lái),以備查詢.

MongoDB的下載與安裝,請(qǐng)參考:

https://blog.51cto.com/hsbxxl/2149500

1. 什么是Replica Set-副本集

副本集就是mongoDB副本所組成的一個(gè)集群。

其原理是,寫操作發(fā)生在主庫(kù),從庫(kù)同步主庫(kù)的OpLog日志。

MongoDB Replica Set 部署MongoDB Replica Set 部署

集群中沒(méi)有特定的主庫(kù),主庫(kù)是選舉產(chǎn)生,如果主庫(kù)down了,會(huì)再選舉出一臺(tái)主庫(kù)。

MongoDB Replica Set 部署                   

MongoDB Replica Set 部署2.早期的MongoDB版本使用master-slave,一主一從和MySQL類似,但slave在此架構(gòu)中為只讀,當(dāng)主庫(kù)宕機(jī)后,從庫(kù)不能自動(dòng)切換為主。目前已經(jīng)淘汰master-slave模式,改為副本集,這種模式下有一個(gè)主(primary),和多個(gè)從(secondary),只讀。支持給它們?cè)O(shè)置權(quán)重,當(dāng)主宕掉后,權(quán)重最高的從切換為主。在此架構(gòu)中還可以建立一個(gè)仲裁(arbiter)的角色,它只負(fù)責(zé)裁決,而不存儲(chǔ)數(shù)據(jù)。此架構(gòu)中讀寫數(shù)據(jù)都是在主上,要想實(shí)現(xiàn)負(fù)載均衡的目的需要手動(dòng)指定讀庫(kù)的目標(biāo)server。

簡(jiǎn)而言之MongoDB 副本集是有自動(dòng)故障恢復(fù)功能的主從集群,有一個(gè)Primary節(jié)點(diǎn)和一個(gè)或多個(gè)Secondary節(jié)點(diǎn)組成。類似于MySQL的MMM架構(gòu)。更多關(guān)于副本集的介紹請(qǐng)見(jiàn)官方文檔:

官方文檔地址:

https://docs.mongodb.com/manual/replication/

 

3. 副本集有以下特點(diǎn):

<1>. 最小構(gòu)成是:primary,secondary,arbiter,一般部署是:primary,2 secondary。

<2>. 成員數(shù)應(yīng)該為奇數(shù),如果為偶數(shù)的情況下添加arbiter,arbiter不保存數(shù)據(jù),只投票。

<3>. 最大50 members,但是只能有 7 voting members,其他是non-voting members。

配置副本集

4. 本次實(shí)驗(yàn),配置的是 1主1從1仲裁 的副本集。兩個(gè)物理機(jī)

host1  192.168.67.101:27017
host2  192.168.67.102:27017
host2  192.168.67.102:27018

5. 分別啟動(dòng)mongo進(jìn)程

host1上啟動(dòng)primary

mongod --port 27017 --dbpath /mongodbs/mgdata/ --logpath /mongodbs/mgdata/db.log --replSet rs0 --fork

host2上啟動(dòng)secondary

mongod --port 27017 --dbpath /mongodbs/mgdata/ --logpath /mongodbs/mgdata/db.log --replSet rs0 --fork

host2上啟動(dòng)arb

mongod --port 28018 --dbpath /mongodbs/arb/ --logpath /mongodbs/arb/db.log --replSet rs0 --fork

6. 配置副本集,由于只有兩臺(tái)物理機(jī),希望host1機(jī)器正常情況下,能更多的做為mongo的primary.所以priority設(shè)置為2

#mongo
> cfg={ _id:"rs0", members:[ {_id:0,host:'192.168.67.101:27017',priority:2},{_id:2,host:'192.168.67.102',priority:1}, {_id:1,host:'192.168.67.102:28018',arbiterOnly:true}]}

7. 執(zhí)行初始化節(jié)點(diǎn)配置

>rs.initiate(cfg)

8. 查看節(jié)點(diǎn)配置&信息

>rs.conf()
> rs.status()

9. 具體命令輸出如下

> cfg={ _id:"rs0", members:[ {_id:0,host:'192.168.67.101:27017',priority:2},{_id:2,host:'192.168.67.102',priority:1}, {_id:1,host:'192.168.67.102:28018',arbiterOnly:true}]}
{
"_id" : "rs0",
"members" : [
{
"_id" : 0,
"host" : "192.168.67.101:27017",
"priority" : 2
},
{
"_id" : 2,
"host" : "192.168.67.102",
"priority" : 1
},
{
"_id" : 1,
"host" : "192.168.67.102:28018",
"arbiterOnly" : true
}
]
}
> rs.initiate(cfg)
{ "ok" : 1 }
rs0:OTHER> rs.conf()
{
"_id" : "rs0",
"version" : 1,
"protocolVersion" : NumberLong(1),
"members" : [
{
"_id" : 0,
"host" : "192.168.67.101:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 2,
"tags" : {
},
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 2,
"host" : "192.168.67.102:27017",
"arbiterOnly" : false,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : {
},
"slaveDelay" : NumberLong(0),
"votes" : 1
},
{
"_id" : 1,
"host" : "192.168.67.102:28018",
"arbiterOnly" : true,
"buildIndexes" : true,
"hidden" : false,
"priority" : 1,
"tags" : {
},
"slaveDelay" : NumberLong(0),
"votes" : 1
}
],
"settings" : {
"chainingAllowed" : true,
"heartbeatIntervalMillis" : 2000,
"heartbeatTimeoutSecs" : 10,
"electionTimeoutMillis" : 10000,
"getLastErrorModes" : {
},
"getLastErrorDefaults" : {
"w" : 1,
"wtimeout" : 0
}
}
}
rs0:SECONDARY> rs.status()
{
"set" : "rs0",
"date" : ISODate("2018-07-24T06:59:34.195Z"),
"myState" : 2,
"term" : NumberLong(2),
"syncingTo" : "192.168.67.101:27017",
"heartbeatIntervalMillis" : NumberLong(2000),
"members" : [
{
"_id" : 0,
"name" : "192.168.67.101:27017",
"health" : 1,
"state" : 1,
"stateStr" : "PRIMARY",
"uptime" : 60,
"optime" : {
"ts" : Timestamp(1532415537, 2),
"t" : NumberLong(2)
},
"optimeDate" : ISODate("2018-07-24T06:58:57Z"),
"lastHeartbeat" : ISODate("2018-07-24T06:59:32.964Z"),
"lastHeartbeatRecv" : ISODate("2018-07-24T06:59:33.372Z"),
"pingMs" : NumberLong(0),
"electionTime" : Timestamp(0, 0),
"electionDate" : ISODate("1970-01-01T00:00:00Z"),
"configVersion" : 1
},
{
"_id" : 1,
"name" : "192.168.67.102:28018",
"health" : 1,
"state" : 7,
"stateStr" : "ARBITER",
"uptime" : 60,
"lastHeartbeat" : ISODate("2018-07-24T06:59:32.957Z"),
"lastHeartbeatRecv" : ISODate("2018-07-24T06:59:30.356Z"),
"pingMs" : NumberLong(0),
"configVersion" : 1
},
{
"_id" : 2,
"name" : "192.168.67.102:27017",
"health" : 1,
"state" : 2,
"stateStr" : "SECONDARY",
"uptime" : 615,
"optime" : {
"ts" : Timestamp(1532415537, 2),
"t" : NumberLong(2)
},
"optimeDate" : ISODate("2018-07-24T06:58:57Z"),
"syncingTo" : "192.168.67.101:27017",
"configVersion" : 1,
"self" : true
}
],
"ok" : 1
}

更多命令

10.添加從庫(kù)命令

rs0:PRIMARY> rs.add('host3:27017')

可以指定priority

rs0:PRIMARY> rs.add({host: "host3:27017", priority: 1})

11. 移除一個(gè)從庫(kù)

先關(guān)閉從庫(kù)的mongoDB,然后在主庫(kù)上移除從庫(kù)

rs0:PRIMARY> rs.remove('host3:27019')

12. 讀寫分離

主庫(kù),從庫(kù)都支持讀操作。但是,默認(rèn)情況讀也是從主庫(kù)來(lái)讀。

從庫(kù)可以通過(guò)設(shè)置ReadPreference打開(kāi)支持讀操作,ReadPreference有幾種模式:

Primary                       #從主庫(kù)讀,默認(rèn)
primaryPreferred                     #基本上從主庫(kù)讀,主不可用時(shí),從從庫(kù)讀
secondary                       #從從庫(kù)讀
secondaryPreferred                      #基本上從從庫(kù)讀,從不可用時(shí),從主庫(kù)讀
nearest                       #從網(wǎng)絡(luò)延遲最小的庫(kù)讀

基本上常用的是,Primary,secondary,nearest

13. 副本集的設(shè)定中可以通過(guò)Tag把成員歸類,通過(guò)下面方法指定讀的類型:

<1>.程序連接的時(shí)候,指定讀的類型ReadPreference

<2>.用mongo命令連接,只對(duì)當(dāng)前連接有效

rs0:SECONDARY> db.getMongo().setReadPref('secondaryPreferred')

14. 特殊成員類型

Secondary還有一些特殊的成員類型:

Priority 0   #不能升為主,可以用于多數(shù)據(jù)中心場(chǎng)景

MongoDB Replica Set 部署MongoDB Replica Set 部署

Hidden     #對(duì)客戶端來(lái)說(shuō)是不可見(jiàn)的,一般用作備份或統(tǒng)計(jì)報(bào)告用

MongoDB Replica Set 部署MongoDB Replica Set 部署

Delayed    #數(shù)據(jù)比副集晚,一般用作 rolling backup 或歷史快照

MongoDB Replica Set 部署MongoDB Replica Set 部署

副本集的配置也是比較簡(jiǎn)單的. 后面有時(shí)間,再分享一下MongoDB Sharded Cluster.

參考鏈接:

https://www.cnblogs.com/ee900222/p/mongodb_2.html

https://blog.51cto.com/zero01/2059033

http://chenzhou123520.iteye.com/blog/1634676

新聞名稱:MongoDBReplicaSet部署
轉(zhuǎn)載來(lái)源:http://jinyejixie.com/article12/pgeddc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、云服務(wù)器企業(yè)建站、品牌網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

營(yíng)銷型網(wǎng)站建設(shè)
敖汉旗| 长春市| 买车| 临猗县| 嘉义县| 和平县| 庆安县| 邵武市| 雅安市| 都匀市| 苍山县| 商河县| 盖州市| 都安| 新民市| 麻江县| 麻江县| 宁海县| 加查县| 五河县| 融水| 合肥市| 岗巴县| 石城县| 高雄县| 库伦旗| 怀集县| 峨边| 新沂市| 贵溪市| 衡阳市| 桃园县| 商水县| 湛江市| 县级市| 大厂| 霍州市| 铜山县| 大名县| 伊吾县| 资兴市|