日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

MongoDB集群之分片技术应用 —— 学习笔记

發布時間:2025/4/16 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MongoDB集群之分片技术应用 —— 学习笔记 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

課程鏈接:https://www.imooc.com/learn/501

一、什么是分片?

分片:將數據進行2拆分,將數據水平的分散到不同的服務器上。

二、為什么要分片?

  • 架構上:讀寫均衡、去中心化
  • 結構上:12節點(version<=2.6)
  • 硬件上:內存、硬盤容量限制

分片目的

改善單臺機器數據的存儲及數據吞吐性能。
提高在大量數據下隨機訪問性能。

分片(Shard)、副本集(Replication)集群對比

成員節點介紹

  • Shard節點:存儲數據的節點(單個mongod或者副本集)
  • Config server:存儲元數據,為mongos服務,將數據路由到Shard。
  • Mongos:接受前端請求,進行對應消息路由。

成員組合圖:

成員節點啟動參數

Shard節點:

  • mongod --shardsvr
  • mongod --shardsvr --rpelSet 副本集

Config server:

  • mongod --configsvr

Mongos:

  • mongos —— configdb <configdb server>

課程使用系統:Red Hat Enterprise Linux Server release 6.4 (Santiago)
課程使用MongoDB版本:v3.0.4

啟動Shard(10.156.11.233):

mongod --shardsvr --logpath=/opt/data/logs/shard.log -logappend --dbpath=/opt/mdb/ --fork --port 27017

查看mongod Shard有沒有啟動起來:

ps -aux | grep mongod netstat -luntp | grep 27017

啟動Config(10.156.11.233):

mongod --configsvr --logpath=/opt/data/logs/config.log --logappend --dbpath=/opt/config --fork --port 27018

查看mongod Config有沒有啟動起來:

netstat -luntp | grep mongo ps -aux | grep mongod

啟動Mongos(10.156.11.232):

mongos --port 27017 --logappend --logpath=/opt/data/logs/mongos.log --configdb 10.156.11.233:27018 --fork

查看Mongos有沒有啟動起來:

netstat -luntp | grep 27017 ps -aux | grep mongos

添加分片過程

步驟一、連接到mongos
步驟二、Add Shards
步驟三、Enable Sharding
步驟四、對一個集合進行分片

步驟二、Add Shards

  • 單個數據庫實例:
    { addShard: "<hostname> <:port>", maxSize: <size>, name: "<shard_name>"}
  • 副本集群:
    { addShard: "<replica_set>/<hostname> <:port>", maxSize:<size>, name: "shard_name" }
  • 如果你的mongos和shard在同一臺機器上,添加分片不能使用“localhost”,建議使用IP。
  • 步驟四、對一個集合進行分片

  • db.runCommand
    ({shardcollection: " <namespoace>", key: " <key>"})
  • unique: " true/false"
    啟動對shard key的唯一性約束
  • shard key選擇
  • 在10.156.11.232上的操作
    這臺電腦之前已經啟動了mongos服務
    輸入如下指令登陸mongos:

    mongo 127.0.0.1:27017

    在mongos命令行下執行如下命令,將10.156.11.232上的mongod添加進來:

    mongos> use admin mongos> db.runCommand({"addShards":"10.156.11.233:27017"})

    其他:
    查看目前有幾個數據庫的mongos命令:

    mongos> show dbs;

    創建名為“shardtest”的數據庫的mongos命令:

    mongos> use shardtest

    測試在數據庫shardtest中的集合userid中插入測試數據的例子:

    mongos> for(i=0;i<10000;i++){db.shardtest.userid.insert({"user_id":i})};

    采用如下命令來Enable剛才創建的名為“shardtest”的Sharding:

    mongos> use admin mongos> db.runCommand({enablesharding:"shardtest"})

    不過這個時候它會報一個這樣的錯誤:

    { "ok": 0, "errmsg": "already enabled" }

    使用如下命令啟用shardtest數據庫的userid集合對應的分片,將根據鍵user_id來進行分片:

    mongos> db.runCommand({"shardcollection":"shardtest.userid",key:{"user_id":1}})

    其中,"user_id"對應的1表示是按照升序來進行分片。

    分片測試

    在mongos命令行執行如下命令:

    mongos> use config mongos> db.shards.find()
  • 查看集合狀態:
  • > use shardtest > db.userid.stats()
  • 查看分片狀態:
  • db.printShardingStatus()
  • 寫入數據測試:
  • for (var i=1;i<10000000;i++>){db.userid.insert(user_id:i)}

    什么是分片片鍵:

    集合里面選一個鍵,用該鍵的值作為數據拆分的依據。

    什么是Chunk:

    MongoDB分片后,存儲數據的但愿快,默認大小:64MB。

    Chunk拆分

    數據塊(chunk)的拆分:
    記錄每個塊中插入多少數據,一旦達到某個閾值,執行檢查是否需要拆分塊,需要則更新config服務器上這個塊的元信息。

    Balancing

    數據塊平衡:
    均衡器負責數據的遷移,會周期性的檢查分片是否存在不均衡,如果存在則會進行塊的遷移。
    注意:均衡器進行均衡的條件是 塊數量的多少 ,而不是塊大小。

    哈希分片

    哈辛分片(hash key):
    分片過程中利用哈希索引作為分片的單個鍵。

    • 哈希分片的片鍵只能使用一個字段
    • 哈希片鍵最大的好處就是保證數據在各個節點分布基本均勻
      shardcollection ==> {userid:"hashed"}

    233上進行如下操作來進行分片:

    mongos> db.userid_hash.insert({userid:11}) mongos> db.userid_hash.insert({userid:22}) mongos> use shardtest mongos> db.userid_hash.ensureIndex({userid:"hash"}) mongos> use admin mongos> db.runCommand({"shardcollection":"shardtest.userid_hash","key":{userid:"hashed"}})

    插入一些數據進行測試:

    mongos> use shardtest mongos> for(i=0;i<100000;i++>{db.userid_hash.insert({userid:i})})

    查看效果:

    mongos> use shardtest mongos> db.userid_hash.stats() mongos> db.printShardingStatus()

    如何選擇合適片鍵

    選擇片鍵的好壞很大程度上影響集群的性能,容量和功能。

    考慮因素一、數據塊的大小
    印象:片鍵相同導致數據塊不拆分,容易形成大的數據塊,導致數據不均。

    考慮因素二、數據寫均勻分布
    影響:單調遞增的_id或時間戳作為片鍵,這樣將會導致你一直往最后一個副本集中添加數據。

    請求查詢機制

    方式一、Routed Request

    方式二、Scatter Gather Request

    方式三、Distributed Merge Sort Req

    手動分片

    為什么要手動分片?
    為了減少自動平衡過程帶來的IO等資源消耗。

    前提:

  • 關閉自動平衡,關閉auto balence;
  • 充分了解數據,并對數據進行預先劃分。
  • 步驟一、關閉自動平衡
    關閉方式:sh.stopBalancer()
    (啟動方式:sh.startBalancer())
    此時平衡器狀態:CurrentLy enabled: no

    步驟二、分片切割

    > use admin > db.runCommand({"enablesharding":"myapp"}) > db.runCommand({"shardcollection":"myapp.users","key":{"email":1}}) for (var x=97;x<97+26;x++) {for (var y=97;y<97+26;y+=6) {var prefix = String.fromCharCode(x) + String.fromCharCode(y);db.runCommand({split: "myapp.users",middle: { email: prefix }});} }

    步驟三、手動移動分割快

    var shServer = ["ShardServer 1","ShardServer 2","ShardServer 3","ShardServer 4","ShardServer 5", ] for (var x=97;x<97+26;x++) {for (var y=97;y<97+26;y+=6) {var prefix = String.fromCharCode(x) + String.fromCharCode(y);db.runCommand({moveChunk: "myapp.users",find: { email: prefix },to: shServer[(y-97)/6]});} }

    實踐:
    首先登陸233的mongos
    執行如下命令來關閉平衡:

    mongos> sh.stopBalancer()

    然后執行下面代碼:

    mongos> for (var x=97;x<97+26;x++) {for (var y=97;y<97+26;y+=6) {var prefix = String.fromCharCode(x) + String.fromCharCode(y);db.runCommand({split: "myapp.users",middle: { email: prefix }});} } mongos> var shServer = ["10.156.11.232:27016","10.156.11.232:27017","10.156.11.232:27016","10.156.11.232:27017","10.156.11.232:27016", ] mongos> for (var x=97;x<97+26;x++) {for (var y=97;y<97+26;y+=6) {var prefix = String.fromCharCode(x) + String.fromCharCode(y);db.runCommand({moveChunk: "myapp.users",find: { email: prefix },to: shServer[(y-97)/6]});} }

    常用部署場景

    場景一

    場景二

    考慮因素:
    一、預估數據增長量
    二、預估集群的訪問量
    三、預估投入成本(硬件、人員維護等)

    場景一部署

    機器規劃:

    三臺電腦均相同方式啟動如下服務:

    mongod --fork --logpath=/opt/data/logs/mongod27018.log -logappend --dbpath=/opt/mdb27018/ --port 27018 --replSet imooc1 mongod --fork --logpath=/opt/data/logs/mongod27019.log -logappend --dbpath=/opt/mdb27019/ --port 27019 --replSet imooc1 mongod --fork --logpath=/opt/data/logs/mongod27020.log -logappend --dbpath=/opt/mdb27020/ --port 27020 --replSet imooc1

    在173節點,執行如下命令進入mongod:

    mongo 127.0.0.1:27018

    在命令行執行如下指令:

    cfg = {_id: 'imooc1', members: [{ _id: 0, host: '10.156.11.173:27018' },{ _id: 1, host: '10.156.11.232:27018' }] }rs.initiate(cfg)rs.addArb("10.156.11.233:27018")

    另外兩臺電腦的配置類似,此處略。

    通過如下命令查看每一個副本集的成員狀態:

    re.status()

    接下來完成對分片的配置(也就是啟動configsvr),
    在清空之前,我要確認我的configsvr的logpath目錄存在,并且log信息是空的:

    rm -rf /opt/data/config/*

    然后啟動configsvr:

    mongod --configsvr --logpath=/opt/data/logs/config.log --logappend /opt/data/config --fork --port 27016

    在三臺電腦上都這么進行啟動configsvr的操作。

    接下來啟動mongos,
    這一步需要將所有的configsvr的配置都加上,
    如下:

    mongos --port 27017 --logappend --logpath=/opt/data/logs/mongos.log --configdb 10.156.11.233:27016,10.156.11.232:27016,10.156.11.173:27016 --fork

    同樣的,我們可以登陸mongos服務:

    mongo 127.0.0.1:27017

    這樣我們就順利地把mongos服務啟動起來。

    接下來登陸到(233上的)mongos上,把我們的成員節點添加進來:
    在命令行下執行mongo進入mongos命令行,然后執行如下命令來進行分片配置操作:

    mongos> use admin mongos> db.runCommand({addshard:"imooc1/10.156.11.173:27018,10.156.11.232:27018",name:"shard1",maxsize:20480}); mongos> db.runCommand({addshard:"imooc2/10.156.11.232:27019,10.156.11.233:27019",name:"shard2",maxsize:20480}); mongos> db.runCommand({addshard:"imooc3/10.156.11.233:27020,10.156.11.173:27020",name:"shard3",maxsize:20480});

    創建一個測試庫:

    mongos> use myimooc mongos> db.user.insert({userid:1,name:"zifeiy",email:"zifeiy@123.com"}) mongos> db.runCommand({ enablesharding:"zifeiy"}) mongos> db.runCommand({"shardcollection":"zifeiy.user","key":{email:1}});

    轉載于:https://www.cnblogs.com/zifeiy/p/9671238.html

    總結

    以上是生活随笔為你收集整理的MongoDB集群之分片技术应用 —— 学习笔记的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 中日韩精品一区二区三区 | 性xxx欧美| 亚州福利 | 2022精品国偷自产免费观看 | 久久综合婷婷国产二区高清 | 国产a√精品区二区三区四区 | 午夜电影网一区 | 欧美乱插 | 亚洲一区二区黄色 | 狠狠爱天天干 | 初尝人妻少妇中文字幕 | 日韩一级影视 | 99ri在线观看| 精品国产aⅴ一区二区三区四川人 | 久久sese| 亚洲永久无码精品一区二区 | av国产精品| 女人和拘做爰正片视频 | 久久超碰在线 | 一级做a免费 | 日韩三级在线播放 | 日本天堂网在线 | 国产一线av | 超碰在线影院 | 精品国产成人亚洲午夜福利 | 日韩中文在线播放 | 一本到在线 | 精品自拍视频 | 蜜桃久久久久久 | 国产精品福利一区二区 | 国产福利二区 | 久久96视频| 久久久久久无码精品大片 | 日本一区视频在线观看 | 日韩综合网站 | 岛国av噜噜噜久久久狠狠av | 色导航在线 | 国产精品黄在线观看 | 国产成人久久精品77777综合 | 国产成人久久77777精品 | 欧美在线免费视频 | 日韩精品无码一区二区 | 人人射 | 久久成人精品一区二区 | 九色.com | 婷婷伊人五月天 | 日韩h在线| 国产夜色视频 | 九色视频在线观看 | 亚洲欧美国产精品专区久久 | 欧美久久久久久久久中文字幕 | 欧美黑人又粗又大的性格特点 | www.五月天婷婷 | 黄色片网站在线观看 | 日韩高清免费观看 | 黄色av电影网址 | 调教一区二区三区 | 天堂视频免费 | 亚洲美女爱爱 | 国产一区二区精品 | 中文字幕视频网站 | 1000部拍拍拍18勿入免费视频 | 好色av| 久久观看| 色666| 韩国三级视频在线观看 | 日韩精品第一 | 国产亚洲性欧美日韩在线观看软件 | 理论片91| 久久性片 | 久久鲁视频 | 成年人av网站| 欧美三日本三级少妇三级99观看视频 | 国产一区二区免费视频 | 青青偷拍视频 | 裸体女视频 | 日韩欧美一区在线观看 | 日本欧美在线视频 | 亚洲av成人无码一区二区三区在线观看 | 成人性生交生交视频 | 伊人超碰| 99蜜桃臀久久久欧美精品网站 | av日韩在线免费观看 | 国偷自产av一区二区三区麻豆 | 中文字幕高清在线播放 | 日本在线中文字幕专区 | 黄色精品 | 大陆一级片 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品一二三四 | 无码播放一区二区三区 | 国产精品区二区三区日本 | 国产精品h | 国产一级爽片 | 久草免费资源站 | 亚洲天堂小视频 | 荫蒂被男人添免费视频 | 午夜精品在线视频 | 婷婷色图 |