摘要:本篇記錄高可用模式部署步驟,其他部署方式見上一篇。首先準備機器,我這里是在公司云平臺創建了三臺,分別是,,。分片的選擇策略可以參考官方文檔。
本篇記錄MongoDB高可用模式部署步驟,其他部署方式見上一篇。
首先準備機器,我這里是在公司云平臺創建了三臺DB server,ip分別是10.199.144.84,10.199.144.89,10.199.144.90。
分別安裝mongodb最新穩定版本:
bashwget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-2.4.12.tgz tar -xzvf mongodb-linux-x86_64-2.4.12.tgz mv mongodb-linux-x86_64-2.4.12 /usr/lib
做個軟連接或者按照官方的做法把mongo shell都添加到環境變量:
bashln -s /usr/lib/mongodb-linux-x86_64-2.4.12/bin/mongo /usr/bin/mongo ln -s /usr/lib/mongodb-linux-x86_64-2.4.12/bin/mongos /usr/bin/mongos ln -s /usr/lib/mongodb-linux-x86_64-2.4.12/bin/mongod /usr/bin/mongod
分別創建存儲數據的目錄:
bashmkdir -p /data/mongodb && cd /data/mongodb/ && mkdir -p conf/data conf/log mongos/log shard{1..3}/data shard{1..3}/log
分別配置啟動config服務器:
bashmongod --configsvr --dbpath /data/mongodb/conf/data --port 27100 --logpath /data/mongodb/conf/confdb.log --fork --directoryperdb
確保config服務都啟動之后,啟動路由服務器(mongos):
bashmongos --configdb 10.199.144.84:27100,10.199.144.89:27100,10.199.144.90:27100 --port 27000 --logpath /data/mongodb/mongos/mongos.log --fork
分別配置啟動各個分片副本集,這里副本集名分別叫shard1,shard2,shard3:
bashmongod --shardsvr --replSet shard1 --port 27001 --dbpath /data/mongodb/shard1/data --logpath /data/mongodb/shard1/log/shard1.log --directoryperdb --fork mongod --shardsvr --replSet shard2 --port 27002 --dbpath /data/mongodb/shard2/data --logpath /data/mongodb/shard2/log/shard2.log --directoryperdb --fork mongod --shardsvr --replSet shard3 --port 27003 --dbpath /data/mongodb/shard3/data --logpath /data/mongodb/shard3/log/shard3.log --directoryperdb --fork
接下來配置副本集,假設使用如下的架構,每臺物理機都有一個主節點,一個副本節點和一個仲裁節點:
配置shard1(登陸84,沒有顯式指定主節點時,會選擇登陸的機器為主節點):
bashmongo --port 27001 use admin rs.initiate({ _id: "shard1", members: [ {_id: 84, host: "10.199.144.84:27001"}, {_id: 89, host: "10.199.144.89:27001"}, {_id: 90, host: "10.199.144.90:27001", arbiterOnly: true} ] });
配置shard2(登陸89):
bashmongo --port 27001 use admin rs.initiate({ _id: "shard2", members: [ {_id: 84, host: "10.199.144.84:27002", arbiterOnly: true}, {_id: 89, host: "10.199.144.89:27002"}, {_id: 90, host: "10.199.144.90:27002"} ] });
配置shard3(登陸90):
bashmongo --port 27001 use admin rs.initiate({ _id: "shard3", members: [ {_id: 84, host: "10.199.144.84:27002"}, {_id: 89, host: "10.199.144.89:27002", arbiterOnly: true}, {_id: 90, host: "10.199.144.90:27002"} ] });
下面設置路由到分片集群配置,隨便登陸一臺機器,假設是84:
bashmongo --port 27000 use admin db.runCommand({addShard: "shard1/10.199.144.84:27001,10.199.144.89:27001,10.199.144.90:27001"}); db.runCommand({addShard: "shard2/10.199.144.84:27002,10.199.144.89:27002,10.199.144.90:27002"}); db.runCommand({addShard: "shard3/10.199.144.84:27003,10.199.144.89:27003,10.199.144.90:27003"});
查看配置好的shard:
bashmongo --port 27000 use admin db.runCommand({listshards: 1});
結果:
bash{ "shards" : [ { "_id" : "shard1", "host" : "shard1/10.199.144.84:27001,10.199.144.89:27001" }, { "_id" : "shard2", "host" : "shard2/10.199.144.89:27002,10.199.144.90:27002" }, { "_id" : "shard3", "host" : "shard3/10.199.144.90:27003,10.199.144.84:27003" } ], "ok" : 1 }
其中仲裁(ARBITER)節點沒有列出來。
下面測試分片:
bashmongo --port 27000 use admin db.runCommand({enablesharding: "dbtest"}); db.runCommand({shardcollection: "dbtest.coll1", key: {id: 1}}); use dbtest; for(var i=0; i<10000; i++) db.coll1.insert({id: i, s: "str_" + i});
如果dbtest已經存在,需要確保它已經以id建立了索引!
過上一段時間之后,運行db.coll1.stats()顯式分片狀態:
bash{ "sharded" : true, "ns" : "dbtest.coll1", "count" : 10000, ... "shards" : { "shard1" : { "ns" : "dbtest.coll1", "count" : 0, "size" : 0, ... }, "shard2" : { "ns" : "dbtest.coll1", "count" : 10000, "size" : 559200, ... } } ... }
可以看到,這里分片已經生效,只是分配不均勻,所有的數據都存在了shard2中了。分片key的選擇策略可以參考官方文檔。在2.4版本中,使用hashed shard key算法保證文檔均勻分布:
bashmongo --port 27000 use admin sh.shardCollection("dbtest.coll1", {id: "hashed"});
使用hashed算法之后,做同樣的測試,插入的數據基本均勻分布:
bash{ "sharded" : true, "ns" : "dbtest.coll1", "count" : 10000, ... "shards" : { "shard1" : { "ns" : "dbtest.coll1", "count" : 3285, "size" : 183672, ... }, "shard2" : { "ns" : "dbtest.coll1", "count" : 3349, "size" : 187360, ... }, "shard3" : { "ns" : "dbtest.coll1", "count" : 3366, "size" : 188168, ... } } }
更多資料,請參考MongoDB Sharding。
在應用程序里,使用MongoClient創建db連接:
javascriptMongoClient.connect("mongodb://10.199.144.84:27000,10.199.144.89:27000,10.199.144.90:27000/dbtest?w=1", function(err, db) { ; });
本篇原地址:https://github.com/chemdemo/chemdemo.github.io/issues/9
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/18720.html
摘要:此文已由作者溫正湖授權網易云社區發布。分片集群通過就可以實現負載均衡,不需要單獨部署負載均衡組件。是一個集群,通過協議保持數據的一致性副本數量可配置,默認保存三副本,并通過做負載均衡調度。 此文已由作者溫正湖授權網易云社區發布。 歡迎訪問網易云社區,了解更多網易技術產品運營經驗。 最近閱讀了TiDB源碼的說明文檔,跟MongoDB的分片集群做了下簡單對比。 首先展示TiDB的整體架構 ...
摘要:以及大數據平臺都已經進行了集成并且處于企業就緒狀態。因此,顧客避免浪費時間在安裝配置及監控系統方面。注意防止數據頻繁移動。 本文源地址:http://www.mongoing.com/blog/post/leaf-in-the-wild-stratio-integrates-apache-spark-and-mongodb-to-unlock-new-customer-insights...
閱讀 1998·2021-11-22 19:20
閱讀 2644·2021-11-22 13:54
閱讀 1976·2021-09-04 16:40
閱讀 1830·2021-08-13 11:54
閱讀 2676·2019-08-30 15:55
閱讀 3470·2019-08-29 13:51
閱讀 532·2019-08-29 11:09
閱讀 3013·2019-08-26 14:06