欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

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

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

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

關于副本集

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

在一些場景,可以使用副本集來擴展讀性能??蛻舳擞心芰Πl送讀寫操作給不同的服務器。
也可以在不同的數據中心獲取不同的副本來擴展分布式應用的能力。

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

Client Application Driver
  Writes  Reads
    |   |
    Primary
  |Replication|Replication
Secondary    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 --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,不使用該參數則默認為分區空間的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 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萬條數據,根據系統不同,可能會花費幾分鐘的時間。
腳本會加入如下格式的文檔:

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 --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
如果使用的是以前創建的表或者測試環境下,可以使用最小的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 --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 通過運行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
}

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

標簽:昭通 丹東 本溪 鶴崗 邯鄲 吉安 大理 景德鎮

巨人網絡通訊聲明:本文標題《詳解MongoDB中用sharding將副本集分配至服務器集群的方法》,本文關鍵詞  詳解,MongoDB,中用,sharding,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解MongoDB中用sharding將副本集分配至服務器集群的方法》相關的同類信息!
  • 本頁收集關于詳解MongoDB中用sharding將副本集分配至服務器集群的方法的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    黄色资源网久久资源365| 亚洲天堂av网站| 摸摸摸bbb毛毛毛片| 88在线观看91蜜桃国自产| 国产精品久久久久久久久免费樱桃 | 婷婷国产v国产偷v亚洲高清| 91蝌蚪国产九色| 五月婷婷一区二区| 中文字幕在线不卡| 成人一道本在线| 婷婷伊人五月天| 国产精品久久久久精k8| 欧美一区二区福利视频| 午夜精品福利一区二区三区蜜桃| 无码人妻久久一区二区三区蜜桃| 欧美色大人视频| 亚洲丰满少妇videoshd| japanese在线观看| 日韩一级完整毛片| 另类人妖一区二区av| 337人体粉嫩噜噜噜| 国产欧美日韩精品一区| 国产91露脸合集magnet| 四虎永久免费在线| 日韩美女久久久| 日本r级电影在线观看 | 欧美va日韩va| 纪美影视在线观看电视版使用方法| 欧美日韩激情一区二区三区| 成人国产精品视频| 国产精品久线观看视频| 久久99国产精品免费| 国产三级短视频| 欧美韩日一区二区三区| 成人黄色在线看| 欧美日韩在线亚洲一区蜜芽| 天天色综合天天| 亚洲精品成人无码| 国产人伦精品一区二区| www.亚洲国产| 欧美美女一区二区三区| 裸体在线国模精品偷拍| 2014亚洲天堂| 怡红院av一区二区三区| 800av在线播放| 久久久99免费| www.亚洲色图.com| 69av一区二区三区| 国内精品免费**视频| 日韩a级片在线观看| 亚洲午夜激情av| 在线免费观看成年人视频| 久久精品视频免费| 99久久精品国产精品久久| 欧美久久久久免费| 韩国视频一区二区| 91久久香蕉国产日韩欧美9色| 亚洲成a人v欧美综合天堂| 公肉吊粗大爽色翁浪妇视频| 亚洲欧美影音先锋| 一区二区视频观看| 中日韩av电影| 色婷婷狠狠18禁久久| 精品国产一二三区| 99re亚洲国产精品| 精品播放一区二区| 91视视频在线观看入口直接观看www | 亚洲色图视频网站| 国产偷人妻精品一区| 国产精品久久免费观看| 成人欧美一区二区三区视频网页| 中文成人无字幕乱码精品区| 中文无字幕一区二区三区| 国产亚洲精品成人a| 国产亚洲欧美日韩日本| 91麻豆免费看| 久久精品视频一区| 久久久久成人精品无码中文字幕| 亚洲欧洲精品天堂一级| 国产精品无码午夜福利| 亚洲精选一二三| 极品尤物一区二区| 亚洲成人www| 色综合天天做天天爱| 奇米色一区二区三区四区| 一本大道综合伊人精品热热 | 欧美日韩在线播| 国产精品69毛片高清亚洲| 制服丝袜亚洲网站| eeuss鲁片一区二区三区 | 日韩不卡av在线| 五月天婷婷综合| 色先锋aa成人| 国产精品一区二区x88av| 欧美一区二区三区播放老司机| av中文字幕不卡| 国产三级久久久| 国产精品三级在线观看无码| 亚洲精品成人a在线观看| 国产在线免费看| 麻豆精品精品国产自在97香蕉| 欧美影视一区在线| 成人一区二区三区中文字幕| 久久只精品国产| 日本一卡二卡在线| 亚洲一区二区偷拍精品| 蜜臀久久精品久久久用户群体| 久久超级碰视频| 91精品国产麻豆国产自产在线| 91在线一区二区| 国产精品免费观看视频| 日韩欧美黄色网址| 麻豆传媒一区二区三区| 日韩天堂在线观看| 精品人妻一区二区三区日产| 亚洲综合色网站| 91福利国产精品| voyeur盗摄精品| 日韩一区欧美小说| 青青草原在线免费观看| 高清在线观看日韩| 亚洲国产精华液网站w| 熟女少妇内射日韩亚洲| 蜜臀久久99精品久久久久宅男 | 日本一区免费视频| 一级肉体全黄裸片| 韩国欧美国产1区| 久久婷婷国产综合精品青草| 亚洲久久久久久久| 久久99热这里只有精品| 精品日韩在线观看| 白丝女仆被免费网站| 男男视频亚洲欧美| 欧美成人综合网站| 亚洲成年人影院| 亚洲精品国产成人久久av盗摄| 中文在线字幕在线观看| 九九久久精品视频| 久久人人超碰精品| 国产精品情侣呻吟对白视频| 国产伦精品一区二区三区免费迷| 国产亚洲va综合人人澡精品| 四虎地址8848| 成人黄色国产精品网站大全在线免费观看| 国产欧美精品区一区二区三区| 久久国产高清视频| 成人激情av网| 一区二区欧美国产| 91精品婷婷国产综合久久性色 | 人妻视频一区二区| 国产精品夜夜嗨| 国产精品国产三级国产普通话蜜臀| 澳门黄色一级片| 久久久久久久久久久影视| 一区二区三区中文字幕精品精品 | 亚洲一区二区三区在线看| 欧美另类久久久品| v8888av| 国产传媒一区在线| 亚洲色图欧美偷拍| 欧美精品第一页| 亚洲AV无码国产成人久久| 国产露脸91国语对白| 亚洲色图色小说| 91麻豆精品国产91| 2019男人天堂| av一二三不卡影片| 天天做天天摸天天爽国产一区| 精品999久久久| 天天色影综合网| 欧美日韩一区二区区别是什么| 日本成人在线网站| 国产欧美日本一区二区三区| 91久久精品国产91性色tv| 在线观看一区二区三区四区| 美国十次综合导航| 国产精品高潮呻吟久久| 欧美另类高清zo欧美| 国产亚洲精品熟女国产成人| 成人av手机在线观看| 午夜a成v人精品| 国产欧美一区二区三区在线看蜜臀| 色成人在线视频| 3d动漫精品啪啪一区二区下载| 国产成人综合网站| 亚洲bdsm女犯bdsm网站| 久久久99久久| 欧美日韩在线电影| 亚洲一区电影在线观看| www男人天堂| 国产风韵犹存在线视精品| 调教+趴+乳夹+国产+精品| 亚洲国产高清不卡| 91精品中文字幕一区二区三区| 狂野欧美性猛交| 美女久久久久久久久| 国产成人精品三级麻豆| 石原莉奈一区二区三区在线观看 | 婷婷色一区二区三区 | 国产精品久久久久久妇女6080|