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

首頁 > 數據庫 > MongoDB > 正文

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

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

關于副本集

副本集是一種在多臺機器同步數據的進程。
副本集體提供了數據冗余,擴展了數據可用性。在多臺服務器保存數據可以避免因為一臺服務器導致的數據丟失。
也可以從硬件故障或服務中斷解脫出來,利用額外的數據副本,可以從一臺機器致力于災難恢復或者備份。

在一些場景,可以使用副本集來擴展讀性能。客戶端有能力發送讀寫操作給不同的服務器。
也可以在不同的數據中心獲取不同的副本來擴展分布式應用的能力。

mongodb副本集是一組擁有相同數據的mongodb實例,主mongodb接受所有的寫操作,所有的其他實例可以接受主實例的操作以保持數據同步。
主實例接受客戶可的寫操作,副本集只能有一個主實例,因為為了維持數據一致性,只有一個實例可寫,主實例的日志保存在oplog。

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

二級節點復制主節點的oplog然后在自己的數據副本上執行操作,二級節點是主節點數據的反射,如果主節點不可用,會選舉一個新的主節點。默認讀操作是在主節點進行的,但是可以指定讀取首選項參數來指定讀操作到副本節點。
可以添加一個額外的仲裁節點(不擁有被選舉權),使副本集節點保持奇數,確??梢赃x舉出票數不同的直接點。仲裁者并不需要專用的硬件設備。
仲裁者節點一直會保存仲裁者身份。

1.異步復制
副本節點同步直接點操作是異步的,然而會導致副本集無法返回最新的數據給客戶端程序。

2.自動故障轉移
如果主節點10s以上與其他節點失去通信,其他節點將會選舉新的節點作為主節點。
擁有大多數選票的副節點會被選舉為主節點。

副本集提供了一些選項給應用程序,可以做一個成員位于不同數據中心的副本集。
也可以指定成員不同的優先級來控制選舉。

sharding轉換一個副本集為分片集群
1. 部署一個測試副本集
創建第一個副本集實例,名稱為firstset:
1.1 創建副本集并且插入數據如下:

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

創建目錄:

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

1.2 在其他終端啟動三個mongodb實例,如下:

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選項強制每個mongodb實例操作日志為700M,不使用該參數則默認為分區空間的5%,限制oplog的大小,可以使每個實例啟動的快一點。
1.3 連接一個mongodb實例的shell

mongo mongo01:10001/admin

如果是運行在生產環境下,或者不同主機名或IP的機器上,需要修改mongo01為指定名稱。
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中創建并插入數據:

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 });}

上面的操作會向集合test_collection插入100萬條數據,根據系統不同,可能會花費幾分鐘的時間。
腳本會加入如下格式的文檔:

2. 部署一個分片設施
創建三個配置服務器來保存集群的元數據。
對于開發或者測試環境下,一個配置服務器足夠了,在生產環境下,需要三天配置服務器,因為它們只需要占用很少的資源來保存元數據。
2.1 創建配置服務器的數據文件保存目錄:

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

創建目錄:

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

2.2 在另外的終端下,啟動配置服務器

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 在另外的終端下,啟動mongos實例:
mongos --configdb mongo01:20001,mongo01:20002,mongo01:20003 --port 27017 --chunkSize 1 --fork --logpath /data/example/mongos.log --logappend
如果使用的是以前創建的表或者測試環境下,可以使用最小的chunksize(1M),默認chunksize為64M意味著在mongodb自動分片啟動前,集群必須擁有64MB的數據文件。
在生產環境下是不能使用很小的分片大小的。
configdb選項指定了配置服務器。mongos實例運行在默認的mongodb27017端口。
2.4 可以在mongos添加第一個分片,在新的終端執行以下命令:
2.4.1 連接mongos實例

mongo mongo01:27017/admin

2.4.2 使用addShard命令添加第一個分片

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

2.4.3 出現以下信息,表示成功:

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

3. 部署另一個測試副本集
創建另外一個副本集實例,名稱為secondset:
3.1 創建副本集并且插入數據如下:

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

創建目錄:

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

3.2 在其他終端啟動三個mongodb實例,如下:

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 連接一個mongodb實例的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 通過運行listShards命令證實分片都添加成功。如下:

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}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品国产乱码久久久久久久久| 91网站在线免费观看| 亚洲精品国产免费| 欧美成人在线影院| 精品亚洲一区二区三区四区五区| 亚洲一区二区久久| 国产精品精品视频一区二区三区| 久久精品久久久久久国产 免费| 国产z一区二区三区| 羞羞色国产精品| 国产欧美va欧美va香蕉在| 亚洲激情视频网站| 亚洲精品www| 国产精品入口日韩视频大尺度| 搡老女人一区二区三区视频tv| 久久久成人av| 欧美专区中文字幕| 欧美网站在线观看| 久久久av免费| 久久亚洲私人国产精品va| 久久综合久中文字幕青草| 日韩中文字幕网站| 日韩精品久久久久久久玫瑰园| 97视频免费在线观看| 亚洲精品成人久久电影| 2019中文字幕免费视频| 国产精品自拍偷拍视频| 国产精品揄拍一区二区| 精品久久久久久| 裸体女人亚洲精品一区| 国产噜噜噜噜噜久久久久久久久| 久久精品国产综合| 久久久久亚洲精品成人网小说| 久久成人这里只有精品| 91精品国产乱码久久久久久久久| 日本午夜精品理论片a级appf发布| 成人网页在线免费观看| 中文国产成人精品| 久久的精品视频| 欧美激情欧美狂野欧美精品| 91九色精品视频| 欧美电影第一页| xxx成人少妇69| 韩国精品美女www爽爽爽视频| 久久久在线视频| 日韩**中文字幕毛片| 亚洲欧美国产va在线影院| 欧美色另类天堂2015| 亚洲精品国产综合区久久久久久久| 精品一区二区三区三区| 欧美精品日韩三级| 91精品视频网站| 九九热r在线视频精品| 亚洲一区二区精品| 久久99精品视频一区97| 国产色婷婷国产综合在线理论片a| 国产一区二区三区视频在线观看| 精品亚洲一区二区三区| 伊人亚洲福利一区二区三区| 亚洲天堂av在线播放| 国外色69视频在线观看| 国产精品白丝av嫩草影院| 亚洲欧美日韩中文在线| 欧美极品少妇与黑人| 亚洲色图国产精品| 日韩av在线不卡| 日韩激情av在线播放| 久久久噜噜噜久噜久久| 午夜精品久久久久久久99热浪潮| 亚洲精品美女在线| 中文字幕亚洲欧美日韩高清| 成人伊人精品色xxxx视频| 精品日韩中文字幕| 久久免费高清视频| 欧美中文字幕第一页| 久久久亚洲福利精品午夜| 欧美在线性爱视频| 亚洲成人av中文字幕| 久久99精品久久久久久琪琪| 精品夜色国产国偷在线| 91成人福利在线| 欧美美女18p| 亚洲国产高清福利视频| 亚洲欧美在线一区二区| 亚洲成人久久网| 伊人久久免费视频| 国产精品扒开腿爽爽爽视频| 一本一本久久a久久精品牛牛影视| 久久久久99精品久久久久| 日韩欧美国产一区二区| 欧美与黑人午夜性猛交久久久| 国产日本欧美一区| 国产91网红主播在线观看| 日韩中文字幕欧美| 亚洲成人久久电影| 日韩中文字幕在线免费观看| 亚洲黄色有码视频| 欧美一级视频一区二区| 亚洲香蕉成视频在线观看| 国模精品视频一区二区| 亚洲午夜色婷婷在线| 亚洲欧美制服综合另类| 国产一区二区三区在线| 国内免费精品永久在线视频| 亚洲精品一区中文| 精品国产乱码久久久久久虫虫漫画| 91精品国产综合久久香蕉的用户体验| 日韩精品在线视频观看| 亚洲国产精品成人va在线观看| 97国产成人精品视频| 国产精品丝袜久久久久久高清| 91麻豆桃色免费看| 亚洲色无码播放| 久久精品国亚洲| 亚洲美女福利视频网站| 国产精品爱啪在线线免费观看| 国产精品日日摸夜夜添夜夜av| 欧美最猛性xxxxx(亚洲精品)| 日韩欧美亚洲综合| 狠狠色噜噜狠狠狠狠97| 成人有码在线播放| 欧美一级电影在线| 欧美在线一级va免费观看| 亚洲国产精品人人爽夜夜爽| 欧洲成人在线观看| 亚洲午夜精品久久久久久性色| 精品高清美女精品国产区| 欧美成年人网站| 81精品国产乱码久久久久久| 性欧美xxxx视频在线观看| 日韩精品亚洲元码| 国产精品美女久久久免费| 国产女同一区二区| 久热精品视频在线观看一区| 欧美富婆性猛交| 欧美电影在线观看| 亚洲免费视频观看| 国产成人久久久精品一区| 久久精品国产免费观看| 亚洲第一中文字幕| 91av免费观看91av精品在线| 亚洲性无码av在线| 国产精品午夜一区二区欲梦| 亚洲午夜未满十八勿入免费观看全集| 亚洲欧美在线一区| 日韩一区视频在线| 日韩黄色av网站| 成人av番号网| 日韩av影院在线观看| 久久精品国产久精国产一老狼| 日韩中文有码在线视频| 精品成人在线视频| 国产日韩欧美91| 久久亚洲国产精品成人av秋霞| 日韩高清av在线| 国产一区二区三区直播精品电影| 日韩精品小视频| 911国产网站尤物在线观看| 欧美日韩国产影院| 国内精品模特av私拍在线观看| 日韩精品高清在线| 精品国产一区二区三区久久狼黑人| 久久久精品在线| 97久久精品在线|