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

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

詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法

2020-10-29 18:49:01
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

關(guān)于副本集

副本集是一種在多臺(tái)機(jī)器同步數(shù)據(jù)的進(jìn)程。
副本集體提供了數(shù)據(jù)冗余,擴(kuò)展了數(shù)據(jù)可用性。在多臺(tái)服務(wù)器保存數(shù)據(jù)可以避免因?yàn)橐慌_(tái)服務(wù)器導(dǎo)致的數(shù)據(jù)丟失。
也可以從硬件故障或服務(wù)中斷解脫出來(lái),利用額外的數(shù)據(jù)副本,可以從一臺(tái)機(jī)器致力于災(zāi)難恢復(fù)或者備份。

在一些場(chǎng)景,可以使用副本集來(lái)擴(kuò)展讀性能??蛻?hù)端有能力發(fā)送讀寫(xiě)操作給不同的服務(wù)器。
也可以在不同的數(shù)據(jù)中心獲取不同的副本來(lái)擴(kuò)展分布式應(yīng)用的能力。

mongodb副本集是一組擁有相同數(shù)據(jù)的mongodb實(shí)例,主mongodb接受所有的寫(xiě)操作,所有的其他實(shí)例可以接受主實(shí)例的操作以保持?jǐn)?shù)據(jù)同步。
主實(shí)例接受客戶(hù)可的寫(xiě)操作,副本集只能有一個(gè)主實(shí)例,因?yàn)闉榱司S持?jǐn)?shù)據(jù)一致性,只有一個(gè)實(shí)例可寫(xiě),主實(shí)例的日志保存在oplog。

Client Application Driver  Writes  Reads    |   |    Primary  |Replication|ReplicationSecondary    Secondary

二級(jí)節(jié)點(diǎn)復(fù)制主節(jié)點(diǎn)的oplog然后在自己的數(shù)據(jù)副本上執(zhí)行操作,二級(jí)節(jié)點(diǎn)是主節(jié)點(diǎn)數(shù)據(jù)的反射,如果主節(jié)點(diǎn)不可用,會(huì)選舉一個(gè)新的主節(jié)點(diǎn)。默認(rèn)讀操作是在主節(jié)點(diǎn)進(jìn)行的,但是可以指定讀取首選項(xiàng)參數(shù)來(lái)指定讀操作到副本節(jié)點(diǎn)。
可以添加一個(gè)額外的仲裁節(jié)點(diǎn)(不擁有被選舉權(quán)),使副本集節(jié)點(diǎn)保持奇數(shù),確??梢赃x舉出票數(shù)不同的直接點(diǎn)。仲裁者并不需要專(zhuān)用的硬件設(shè)備。
仲裁者節(jié)點(diǎn)一直會(huì)保存仲裁者身份。

1.異步復(fù)制
副本節(jié)點(diǎn)同步直接點(diǎn)操作是異步的,然而會(huì)導(dǎo)致副本集無(wú)法返回最新的數(shù)據(jù)給客戶(hù)端程序。

2.自動(dòng)故障轉(zhuǎn)移
如果主節(jié)點(diǎn)10s以上與其他節(jié)點(diǎn)失去通信,其他節(jié)點(diǎn)將會(huì)選舉新的節(jié)點(diǎn)作為主節(jié)點(diǎn)。
擁有大多數(shù)選票的副節(jié)點(diǎn)會(huì)被選舉為主節(jié)點(diǎn)。

副本集提供了一些選項(xiàng)給應(yīng)用程序,可以做一個(gè)成員位于不同數(shù)據(jù)中心的副本集。
也可以指定成員不同的優(yōu)先級(jí)來(lái)控制選舉。

sharding轉(zhuǎn)換一個(gè)副本集為分片集群
1. 部署一個(gè)測(cè)試副本集
創(chuàng)建第一個(gè)副本集實(shí)例,名稱(chēng)為firstset:
1.1 創(chuàng)建副本集并且插入數(shù)據(jù)如下:

  /data/example/firstset1  /data/example/firstset2  /data/example/firstset3

創(chuàng)建目錄:

mkdir -p /data/example/firstset1 /data/example/firstset2 /data/example/firstset3

1.2 在其他終端啟動(dòng)三個(gè)mongodb實(shí)例,如下:

mongod --dbpath /data/example/firstset1 --port 10001 --replSet firstset --oplogSize 700 --rest --fork --logpath /data/example/firstset1/firstset1.log --logappend --nojournal --directoryperdbmongod --dbpath /data/example/firstset2 --port 10002 --replSet firstset --oplogSize 700 --rest --fork --logpath /data/example/firstset2/firstset2.log --logappend --nojournal --directoryperdbmongod --dbpath /data/example/firstset3 --port 10003 --replSet firstset --oplogSize 700 --rest --fork --logpath /data/example/firstset3/firstset3.log --logappend --nojournal --directoryperdb

--oplog選項(xiàng)強(qiáng)制每個(gè)mongodb實(shí)例操作日志為700M,不使用該參數(shù)則默認(rèn)為分區(qū)空間的5%,限制oplog的大小,可以使每個(gè)實(shí)例啟動(dòng)的快一點(diǎn)。
1.3 連接一個(gè)mongodb實(shí)例的shell

mongo mongo01:10001/admin

如果是運(yùn)行在生產(chǎn)環(huán)境下,或者不同主機(jī)名或IP的機(jī)器上,需要修改mongo01為指定名稱(chēng)。
1.4 在mongo shell上初始化副本集

var config = {  "_id" : "firstset",  "members" : [    {"_id" : 0, "host" : "mongo01:10001"},    {"_id" : 1, "host" : "mongo01:10002"},    {"_id" : 2, "host" : "mongo01:10003"},  ]}rs.initiate(config);{    "info" : "Config now saved locally. Should come online in about a minute.",    "ok" : 1}


db.runCommand(  {"replSetInitiate" :    {"_id" : "firstset",    "members" : [      {"_id" : 0, "host" : "mongo01:10001"},      {"_id" : 1, "host" : "mongo01:10002"},      {"_id" : 2, "host" : "mongo01:10003"}      ]    }  })

1.5 在mongo shell中創(chuàng)建并插入數(shù)據(jù):

use mydbswitched to db mydbanimal = ["dog", "tiger", "cat", "lion", "elephant", "bird", "horse", "pig", "rabbit", "cow", "dragon", "snake"];for(var i=0; i<100000; i++){  name = animal[Math.floor(Math.random()*animal.length)];  user_id = i;  boolean = [true, false][Math.floor(Math.random()*2)];  added_at = new Date();  number = Math.floor(Math.random()*10001);  db.test_collection.save({"name":name, "user_id":user_id, "boolean": boolean, "added_at":added_at, "number":number });}

上面的操作會(huì)向集合test_collection插入100萬(wàn)條數(shù)據(jù),根據(jù)系統(tǒng)不同,可能會(huì)花費(fèi)幾分鐘的時(shí)間。
腳本會(huì)加入如下格式的文檔:

2. 部署一個(gè)分片設(shè)施
創(chuàng)建三個(gè)配置服務(wù)器來(lái)保存集群的元數(shù)據(jù)。
對(duì)于開(kāi)發(fā)或者測(cè)試環(huán)境下,一個(gè)配置服務(wù)器足夠了,在生產(chǎn)環(huán)境下,需要三天配置服務(wù)器,因?yàn)樗鼈冎恍枰加煤苌俚馁Y源來(lái)保存元數(shù)據(jù)。
2.1 創(chuàng)建配置服務(wù)器的數(shù)據(jù)文件保存目錄:

  /data/example/config1  /data/example/config2  /data/example/config3

創(chuàng)建目錄:

mkdir -p /data/example/config1 /data/example/config2 /data/example/config3

2.2 在另外的終端下,啟動(dòng)配置服務(wù)器

mongod --configsvr --dbpath /data/example/config1 --port 20001 --fork --logpath /data/example/config1/config1.log --logappendmongod --configsvr --dbpath /data/example/config2 --port 20002 --fork --logpath /data/example/config2/config2.log --logappendmongod --configsvr --dbpath /data/example/config3 --port 20003 --fork --logpath /data/example/config3/config3.log --logappend

2.3 在另外的終端下,啟動(dòng)mongos實(shí)例:
mongos --configdb mongo01:20001,mongo01:20002,mongo01:20003 --port 27017 --chunkSize 1 --fork --logpath /data/example/mongos.log --logappend
如果使用的是以前創(chuàng)建的表或者測(cè)試環(huán)境下,可以使用最小的chunksize(1M),默認(rèn)chunksize為64M意味著在mongodb自動(dòng)分片啟動(dòng)前,集群必須擁有64MB的數(shù)據(jù)文件。
在生產(chǎn)環(huán)境下是不能使用很小的分片大小的。
configdb選項(xiàng)指定了配置服務(wù)器。mongos實(shí)例運(yùn)行在默認(rèn)的mongodb27017端口。
2.4 可以在mongos添加第一個(gè)分片,在新的終端執(zhí)行以下命令:
2.4.1 連接mongos實(shí)例

mongo mongo01:27017/admin

2.4.2 使用addShard命令添加第一個(gè)分片

db.runCommand( { addShard : "firstset/mongo01:10001,mongo01:10002,mongo01:10003" } )

2.4.3 出現(xiàn)以下信息,表示成功:

{ "shardAdded" : "firstset", "ok" : 1 }

3. 部署另一個(gè)測(cè)試副本集
創(chuàng)建另外一個(gè)副本集實(shí)例,名稱(chēng)為secondset:
3.1 創(chuàng)建副本集并且插入數(shù)據(jù)如下:

  /data/example/secondset1  /data/example/secondset2  /data/example/secondset3

創(chuàng)建目錄:

mkdir -p /data/example/secondset1 /data/example/secondset2 /data/example/secondset3

3.2 在其他終端啟動(dòng)三個(gè)mongodb實(shí)例,如下:

mongod --dbpath /data/example/secondset1 --port 30001 --replSet secondset --oplogSize 700 --rest --fork --logpath /data/example/secondset1/secondset1.log --logappend --nojournal --directoryperdbmongod --dbpath /data/example/secondset2 --port 30002 --replSet secondset --oplogSize 700 --rest --fork --logpath /data/example/secondset2/secondset2.log --logappend --nojournal --directoryperdbmongod --dbpath /data/example/secondset3 --port 30003 --replSet secondset --oplogSize 700 --rest --fork --logpath /data/example/secondset3/secondset3.log --logappend --nojournal --directoryperdb

3.3 連接一個(gè)mongodb實(shí)例的shell

mongo mongo01:20001/admin

3.4 在mongo shell上初始化副本集

db.runCommand(  {"replSetInitiate" :    {"_id" : "secondset",    "members" : [      {"_id" : 0, "host" : "mongo01:30001"},      {"_id" : 1, "host" : "mongo01:30002"},      {"_id" : 2, "host" : "mongo01:30003"}      ]    }  })

3.5 將該副本集加入分片集群

db.runCommand( { addShard : "secondset/mongo01:30001,mongo01:30002,mongo01:30003" } )

返回成功信息:

{ "shardAdded" : "firstset", "ok" : 1 }

3.6 通過(guò)運(yùn)行l(wèi)istShards命令證實(shí)分片都添加成功。如下:

db.runCommand({listShards:1}){  "shards" : [    {      "_id" : "firstset",      "host" : "firstset/mongo01:10001,mongo01:10002,mongo01:10003"    },    {      "_id" : "secondset",      "host" : "secondset/mongo01:30001,mongo01:30002,mongo01:30003"    }  ],  "ok" : 1}

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
天天色影综合网| 国内自拍欧美激情| 狠狠色丁香婷婷综合久久片| 午夜午夜精品一区二区三区文| 色一情一乱一区二区三区| 亚洲色婷婷一区二区三区| 国产福利一区在线| 成人白浆超碰人人人人| 99er精品视频| www日韩中文字幕在线看| 天天色图综合网| 欧美日韩伦理在线免费| 男人添女人下部视频免费| 国产一区二区电影在线观看| 国产精品入口免费软件| 丁香五六月婷婷久久激情| 综合av在线| 色婷婷综合久久久久久| 337p亚洲精品色噜噜狠狠p| 337p亚洲精品色噜噜狠狠p| 男人插女人下面免费视频| 好吊妞www.84com只有这里才有精品| 成人网页在线观看| 粉嫩av蜜桃av蜜臀av| www.国产黄色| 免费一级毛片在线观看| 欧美高跟鞋交xxxxhd| 中文字幕在线亚洲三区| 国内精品久久久久久不卡影院| 亚洲免费成人av电影| 一本色道久久综合狠狠躁的番外| 国产精品日韩欧美大师| 九七影院97影院理论片久久| 日韩欧美在线一区| 亚洲精品乱码久久久久久蜜桃图片| 亚洲一区二区在线| 催眠调教后宫乱淫校园| 欧美激情另类| 天堂在线免费观看视频| 天堂精品在线视频| 亚洲黄色在线观看| 99久久精品无免国产免费| 先锋影音在线资源站91| 成人精品动漫| 意大利激情丛林无删减版dvd| 99久久国产综合精品五月天喷水| 国产精品自偷自拍| 色狠狠av一区二区三区香蕉蜜桃| 欧美在线视频不卡| 91大神在线资源观看无广告| 亚洲sss视频在线视频| 欧美体内she精高潮| 亚洲久久在线观看| 欧美二区乱c少妇| 日韩在线视频网站| 欧美久久一二三四区| 黄色手机在线视频| 97精品在线播放| 日韩av三级在线| 国产欧美一区二区精品忘忧草| 99久久免费国产| 精品福利影院| 久久99久久99精品免观看软件| 国产 日韩 欧美一区| 欧美五码在线| 欧美videossexotv100| 欧美电影院免费观看| 爱情岛论坛亚洲入口| 欧美极品美女视频网站在线观看免费| 欧美电影免费观看高清| 福利一区二区三区视频在线观看| 国产精品1区2区3区4区| 中文字幕日本不卡| 在线天堂中文www视软件| 久久人人九九| 一区二区三区欧洲区| 国产亚洲一区字幕| 日韩一区二区在线| 97成人在线观看| 色综合激情五月| av在线收看| 麻豆免费视频网站入口| 欧美无人区码suv| 国产免费人做人爱午夜视频| 亚洲精品91美女久久久久久久| 一区二区三区四区在线免费视频| 久久中文资源| 丝袜亚洲精品中文字幕一区| 免费看一级视频| 免费男女羞羞的视频网站中文字幕妖精视频| 亚洲性夜色噜噜噜7777| 亚洲美女偷拍久久| 久久深夜福利免费观看| 麻豆精品在线播放| 日韩精品免费一区二区夜夜嗨| 天天干天天操天天玩| 国产视频网站在线| 欧美成人激情视频免费观看| 亚洲一二三在线| 男人天堂网av| 丰满肉嫩西川结衣av| 国产精品电影一区二区三区| 国产a亚洲精品| 午夜3点看的视频| 国产又粗又长又大的视频| 国产青青在线视频| 九九色在线观看| 国产精品自拍首页| 国产精品毛片一区二区三区| 四虎精品一区二区三区| 奇米影视一区二区三区| 欧美三级伦理在线| 久久久久久久久久久影院| 成人亚洲精品7777| 妺妺窝人体色777777| 一区av在线播放| 日韩中文字幕久久| 中文字幕日韩免费视频| 在线成人av观看| 亚洲国产精品人久久电影| 97精品国产97久久久久久免费| 秋霞午夜在线观看| 中文字幕免费视频观看| 国产精品福利视频| 91麻豆swag| 国产精品自拍一区| 日本午夜精品一区二区| 欧美拍拍视频| 国产日韩一区二区三区在线播放| 日韩大片在线观看| 五月天亚洲综合小说网| 中文字幕亚洲影院| 波多野在线播放| 免费**毛片在线| 亚洲码在线观看| 成人午夜在线视频| 在线激情小视频| 亚洲欧美综合国产精品一区| 国产成人黄色| 欧美成人a∨高清免费观看| 色吊丝在线永久观看最新版本| 精品欧美一区二区精品少妇| 日本暖暖在线视频| 无码人妻精品一区二区50| 国产日韩欧美另类| 精品国产一区二区三区不卡在线| 里番全彩acg☆无翼乌全彩3d| 一区二区三区高清| 免费黄色网页在线观看| 无码人妻丰满熟妇区五十路百度| 亚洲精品二区| 婷婷五月色综合| 久久se精品一区精品二区| 欧美性色黄大片手机版| 日本高清好狼色视频| 岛国av在线一区| 一区二区三区国产好| 色综合影院在线| 国模一区二区三区白浆| 亚洲第一中文av| 国产一区免费在线观看| 国产无色aaa| 中文字幕精品一区二区精品绿巨人| 欧美成人在线免费| 欧美成人综合网站| 老司机福利av| 亚洲影视资源网| 超碰免费在线公开| 91cn在线观看| 成人午夜免费剧场| 国产传媒免费观看| 久久av一区二区| 国产区卡一卡二卡三乱码免费| 大地资源高清在线视频观看| 亚洲成av人片一区二区三区| 亚洲欧美日韩国产一区二区三区| 国产成人在线影院| 国产经典一区二区| 老女人性生活视频| 久久精品国产电影| 99久久激情视频| 91精品视频免费看| 国产福利资源在线| 成年人黄色网址| eeuss国产一区二区三区| 日本一区二区在线播放| 亚洲国产色一区| 亚洲欧美日韩国产综合| 日韩美女写真福利在线观看| 中文字幕国产免费| 日本免费视频在线观看| 中文字幕日韩欧美精品高清在线| 少妇久久久久久| 麻豆福利在线观看| 亚洲综合爱爱久久网| 国产素人视频在线观看| 国产精品特级毛片一区二区三区| 97免费中文视频在线观看| 中文字幕在线观看的网站| 国产视频手机在线观看| 丝袜脚交一区二区| 国产视频精选在线| 午夜毛片在线观看| 九九九精品视频| 无夜福利视频观看| 成人av网站免费观看| 日韩成人在线视频观看| 2021久久精品国产99国产精品| 青青青在线视频| 可以直接看的无码av| 秋霞午夜鲁丝一区二区| 精品国产一二三四区| 在线黄色国产电影| 自拍视频网站| av一区二区不卡| 免费三级网站| 亚洲精品中文字幕在线观看| 亚洲欧美一区二区激情| 亚洲美女在线播放| 26uuu精品一区二区三区四区在线| 实拍女处破www免费看| 97se在线视频| av男人天堂一区| 一区二区三区四区视频免费观看| chinesegaysextube| 亚洲精品人成| 亚洲AV无码成人精品区明星换面| 美女在线观看视频一区二区| 亚洲a级黄色片| 黄色欧美在线| 日韩av网站导航| 日本不卡高字幕在线2019| 成人亚洲欧美| 狠狠操狠狠色综合网| 国产精品51麻豆cm传媒| 黄视频在线免费看| 欧美熟妇精品一区二区| av免费在线观看网址| 欧美一级片免费播放| 91精品一区国产高清在线gif| 77成人影视| 成年网在线观看免费观看网址| 久久毛片高清国产| 免费久久久久久久久| 国产在线拍揄自揄视频不卡99| 一区二区在线高清视频| 免费91麻豆精品国产自产在线观看| 精品无码久久久久久久久| 日本少妇做爰全过程毛片| 欧美亚洲另类制服自拍| 欧洲亚洲一区二区| 欧美日韩国产免费观看| 日韩第一页在线观看| 中文字幕一区二区三区四区免费看| 另类天堂视频在线观看| 亚洲黄色小说网站| 久草热在线观看| 国产精品一区二区久久精品| 韩国av一区二区三区在线观看| 9797在线看片亚洲精品| 一级片在线观看免费| 先锋影音久久久| 自拍欧美一区| 粉嫩av一区二区三区四区五区| 在线一区二区视频| 中文字幕手机在线视频| 亚洲欧美清纯在线制服| 中文字幕亚洲专区| 欧美精品卡一卡二| 久热国产精品视频| 一级特黄色大片| 日本一区精品久久久久影院| 国产福利拍拍拍| 亚洲色图在线播放| 天天干天天干天天干天天| 久久aⅴ国产欧美74aaa| 日本在线高清视频一区| 久久精品无码专区| av中文在线资源| 8050国产精品久久久久久| 最新黄色网址在线观看| 欧美一激情一区二区三区| 日韩电影一区| 欧美中文在线观看| 亚洲福利免费| 亚洲狠狠婷婷综合久久蜜桃| 粉嫩av一区二区三区天美传媒| 亚洲第一中文字幕| 在线观看精品视频一区二区三区| 亚洲黄色成人网| 日本一线产区和二线产区| 97高清视频| 日本一区高清| 中文字幕在线看高清电影| 91免费网站视频| 亚洲av激情无码专区在线播放| 99视频精品全部免费在线视频| 欧美日本另类xxx乱大交| 成人的网站免费观看| 污网站免费在线观看| 制服.丝袜.亚洲.中文.综合懂色| 污视频网站在线| 午夜精品小视频| 欧美资源一区| 影音先锋日韩在线| 久久精品人人| 欧美日韩成人影院| 久久er热在这里只有精品66| 日韩一区二区三区观看| 欧美性色黄大片| 国产美女特级嫩嫩嫩bbb片| 一色屋免费视频| 久久综合图区亚洲综合图区| 国产精品欧美激情| 国产一二在线播放| 国产精品久久久久久久久久ktv| 99久久99精品| 亚洲精品成av人片天堂无码| 九九热这里只有精品免费看| 欧美肥婆xxxx欧美另类| www.亚洲一区二区| 麻豆久久一区| 国偷自产av一区二区三区小尤奈| 中文字幕精品—区二区| 四虎4hu新地址入口2023| 在线成人直播| 国产日本欧美一区| 欧美a一区二区|