亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

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

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

熱門標(biāo)簽:兗州電話外呼營銷系統(tǒng) 企業(yè)智能外呼系統(tǒng)價格多少 南京400電話怎樣辦理 徐州ai電銷機器人原理 福州電銷機器人源代碼 機器人外呼系統(tǒng)軟件存在問題 高德地圖標(biāo)注商戶位置 智能電銷機器人銷售話術(shù) 沈陽營銷電銷機器人招商

關(guān)于副本集

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

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

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

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

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

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

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

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

sharding轉(zhuǎn)換一個副本集為分片集群
1. 部署一個測試副本集
創(chuà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 在其他終端啟動三個mongodb實例,如下:

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

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

mongo mongo01:10001/admin

如果是運行在生產(chǎn)環(huán)境下,或者不同主機名或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中創(chuàng)建并插入數(shù)據(jù):

use mydb
switched to db mydb
animal = ["dog", "tiger", "cat", "lion", "elephant", "bird", "horse", "pig", "rabbit", "cow", "dragon", "snake"];
for(var i=0; i100000; 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萬條數(shù)據(jù),根據(jù)系統(tǒng)不同,可能會花費幾分鐘的時間。
腳本會加入如下格式的文檔:

2. 部署一個分片設(shè)施
創(chuàng)建三個配置服務(wù)器來保存集群的元數(shù)據(jù)。
對于開發(fā)或者測試環(huán)境下,一個配置服務(wù)器足夠了,在生產(chǎn)環(huán)境下,需要三天配置服務(wù)器,因為它們只需要占用很少的資源來保存元數(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 在另外的終端下,啟動配置服務(wù)器

mongod --configsvr --dbpath /data/example/config1 --port 20001 --fork --logpath /data/example/config1/config1.log --logappend
mongod --configsvr --dbpath /data/example/config2 --port 20002 --fork --logpath /data/example/config2/config2.log --logappend
mongod --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
如果使用的是以前創(chuàng)建的表或者測試環(huán)境下,可以使用最小的chunksize(1M),默認(rèn)chunksize為64M意味著在mongodb自動分片啟動前,集群必須擁有64MB的數(shù)據(jù)文件。
在生產(chǎn)環(huán)境下是不能使用很小的分片大小的。
configdb選項指定了配置服務(wù)器。mongos實例運行在默認(rèn)的mongodb27017端口。
2.4 可以在mongos添加第一個分片,在新的終端執(zhí)行以下命令:
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 出現(xiàn)以下信息,表示成功:

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

3. 部署另一個測試副本集
創(chuà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 在其他終端啟動三個mongodb實例,如下:

mongod --dbpath /data/example/secondset1 --port 30001 --replSet secondset --oplogSize 700 --rest --fork --logpath /data/example/secondset1/secondset1.log --logappend --nojournal --directoryperdb
mongod --dbpath /data/example/secondset2 --port 30002 --replSet secondset --oplogSize 700 --rest --fork --logpath /data/example/secondset2/secondset2.log --logappend --nojournal --directoryperdb
mongod --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 通過運行l(wèi)istShards命令證實分片都添加成功。如下:

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
}

您可能感興趣的文章:
  • MongoDB的主從復(fù)制及副本集的replSet配置教程
  • Mongodb 副本集搭建問題總結(jié)及解決辦法
  • Mongodb3.0.5 副本集搭建及spring和java連接副本集配置詳細(xì)介紹
  • mongodb3.4集群搭建實戰(zhàn)之高可用的分片+副本集
  • Mongodb副本集和分片示例詳解
  • CentOS 6.4創(chuàng)建Mongodb副本集
  • MongoDB副本集丟失數(shù)據(jù)的測試實例教程
  • MongoDB 復(fù)制(副本集)學(xué)習(xí)筆記
  • mongodb 4.0副本集搭建的全過程

標(biāo)簽:昭通 丹東 本溪 鶴崗 邯鄲 吉安 大理 景德鎮(zhèn)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法》,本文關(guān)鍵詞  詳解,MongoDB,中用,sharding,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解MongoDB中用sharding將副本集分配至服務(wù)器集群的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    一本高清在线| 99色视频在线观看| 精品视频在线观看一区二区三区| 国产不卡精品一区二区三区| 国产精品自拍亚洲| 99久久网站| 99色视频在线观看| 青草国产在线观看| 国产成人精品一区二区视频| 成人免费高清视频| 国产网站免费视频| 日本特黄特黄aaaaa大片| 九九九网站| 黄视频网站在线免费观看| 国产伦理精品| 国产网站免费| 可以免费看毛片的网站| 国产a视频精品免费观看| a级毛片免费全部播放| 国产伦精品一区二区三区无广告| 免费国产在线观看不卡| 亚欧成人乱码一区二区| 日韩综合| 国产视频一区在线| 国产伦精品一区三区视频| 精品国产一区二区三区免费 | 久久久久久久男人的天堂| 国产91精品系列在线观看| 国产一区二区精品| 午夜久久网| 99久久视频| 国产原创中文字幕| 久久久成人影院| 欧美1区2区3区| 久久成人综合网| 精品在线观看国产| 精品国产三级a| 999精品视频在线| 中文字幕一区二区三区精彩视频| 国产欧美精品午夜在线播放| 可以免费看污视频的网站| 亚洲www美色| 麻豆系列 在线视频| 欧美一区二区三区在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产国产人免费视频成69堂| 韩国毛片免费| 国产成人精品一区二区视频| 九九久久国产精品大片| 一 级 黄 中国色 片| 国产伦精品一区三区视频| 精品视频在线看| 999久久66久6只有精品| 高清一级做a爱过程不卡视频| 亚洲 国产精品 日韩| 99色视频在线| 精品视频在线观看免费| 国产视频一区在线| 国产a视频| 天天做人人爱夜夜爽2020毛片| 久久精品道一区二区三区| 精品久久久久久中文| 国产网站在线| 沈樵在线观看福利| 高清一级片| 毛片成人永久免费视频| 久久成人综合网| 日本免费乱人伦在线观看| 黄视频网站免费| 九九干| 国产极品精频在线观看| 天天色色色| 国产麻豆精品免费视频| 国产一区二区精品久久| 亚洲第一色在线| 日韩在线观看网站| 黄视频网站在线免费观看| 青青青草视频在线观看| 国产成人精品影视| 一 级 黄 中国色 片| 欧美激情一区二区三区在线| 成人免费观看男女羞羞视频| 毛片成人永久免费视频| 日韩男人天堂| 久草免费在线色站| 99久久精品国产免费| 国产成人精品一区二区视频| 999精品视频在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情在线精品video| 麻豆网站在线看| 一级片片| 亚洲第一页乱| 日本特黄特黄aaaaa大片| 国产成人啪精品视频免费软件| 麻豆污视频| 国产网站在线| 久久国产精品自由自在| 国产不卡在线观看视频| 亚洲第一页乱| 国产一区精品| 欧美一级视频免费| 欧美另类videosbestsex高清| 精品国产亚一区二区三区| 精品久久久久久中文字幕2017| 99热精品在线| 亚欧成人乱码一区二区| 国产一区免费在线观看| 天天做日日干| 91麻豆国产| 香蕉视频久久| 国产麻豆精品| 日韩男人天堂| 在线观看成人网 | 精品久久久久久中文| 成人免费一级纶理片| 美女免费精品视频在线观看| 亚洲精品久久玖玖玖玖| 久久久久久久久综合影视网| 精品国产亚洲人成在线| 97视频免费在线观看| 欧美日本国产| 成人免费一级纶理片| 黄视频网站免费| 亚洲第一色在线| 一 级 黄 中国色 片| 国产综合成人观看在线| 四虎久久精品国产| 亚洲天堂免费| 一级毛片看真人在线视频| 日本伦理片网站| 日韩专区第一页| 九九久久国产精品| 欧美激情一区二区三区视频| 国产极品精频在线观看| 九九免费精品视频| 天天综合在线观看 | 精品视频在线看| 九九九国产| 精品久久久久久中文| 亚洲第一色在线| 99久久精品国产麻豆| 久久精品大片| 国产精品自拍一区| 国产成人精品综合久久久| 亚洲精品影院一区二区| 国产精品自拍一区| 国产网站免费| 日韩在线观看网站| 九九干| 国产成人精品综合| 精品国产香蕉在线播出| 国产精品123| 国产a一级| 午夜在线亚洲| 黄视频网站在线免费观看| 国产成人欧美一区二区三区的| 国产91丝袜高跟系列| 天天做日日爱| 欧美激情一区二区三区在线播放 | 亚洲精品影院| 一级毛片视频免费| 九九九国产| 日韩中文字幕在线播放| 国产视频久久久| 99色播| 精品久久久久久综合网| 成人a大片高清在线观看| 91麻豆精品国产自产在线| 四虎影视久久久免费| 在线观看成人网 | 亚洲精品久久久中文字| 久久精品成人一区二区三区| 可以免费看污视频的网站| 精品视频在线观看免费| 青青久久精品| 色综合久久天天综合| 97视频免费在线观看| 久久国产精品只做精品| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产麻豆精品| 国产一区二区精品久| 九九热国产视频| 国产一区二区福利久久| 麻豆网站在线看| 可以免费看污视频的网站| 91麻豆爱豆果冻天美星空| 国产成a人片在线观看视频| 精品国产一区二区三区精东影业| 国产综合成人观看在线| 精品国产亚洲人成在线| 亚欧乱色一区二区三区| 精品国产三级a| 欧美爱色| 午夜在线影院| 亚洲精品永久一区| 国产一区二区精品| 日韩男人天堂| 国产一区二区福利久久| 亚欧视频在线|