MongoDB Auto-Sharding 解决了海量存储和动态扩容的问题但离实际生产环境所需的高可靠、高可用还有些距离所以有了” Replica Sets + Sharding”的解决方案。
MongoDB Auto-Sharding 解决了海量存储和动态扩容的问题但离实际生产环境所需的高可靠、高可用还有些距离所以有了” Replica Sets + Sharding”的解决方案。
1、Shard:
使用 Replica Sets确保每个数据节点都具有备份、自动容错转移、自动恢复能力。
2、Config:
使用3 个配置服务器确保元数据完整性
3、Route:
使用3 个路由进程实现负载平衡提高客户端接入性能
以下我们配置一个 Replica Sets + Sharding 的环境架构图如下
data:image/s3,"s3://crabby-images/5cd72/5cd72299dc3e6d54aaa6b8a3f24680d3eb0fe025" alt="QQ截图20131126220633.png 220644433.png"
开放的端口如下
主机 |
ip |
服务及端口 |
Server A |
192.168.3.231 |
mongod shard1_1:27017
mongod shard2_1:27018
mongod config1:20000
mongs1:30000 |
Server B |
192.168.3.232 |
mongod shard1_2:27017
mongod shard2_2:27018
mongod config2:20000
mongs2:30000 |
Server C |
192.168.3.233 |
mongod shard1_3:27017
mongod shard2_3:27018
mongod config3:20000
mongs3:30000 |
创建数据目录
在Server A 上:
data:image/s3,"s3://crabby-images/7b9c0/7b9c0cee62989847a69e0119f30c58ed825ea4e9" alt="QQ截图20131126220633.png 221548354.png"
在Server B 上:
data:image/s3,"s3://crabby-images/a0a0d/a0a0d65cc0f7a332f74f41ecc7a52df42fbee28f" alt="QQ截图20131126220633.png 221741790.png"
在Server C 上:
data:image/s3,"s3://crabby-images/00c90/00c902a2df02905ee293ef9dded213fd812c2981" alt="QQ截图20131126220633.png 221901658.png"
配置Replica Sets
1、配置shard1所用到的Replica Sets
在Server A 上:
data:image/s3,"s3://crabby-images/82841/82841edcaa03a461929ccfdf27efa94389c57ca7" alt="QQ截图20131126220633.png 224244412.png"
在Server B 上:
data:image/s3,"s3://crabby-images/30019/300197fd3ff1dd0bad30f4daf34b87081ffcb33e" alt="QQ截图20131126220633.png 224717560.png"
在Server C 上:
data:image/s3,"s3://crabby-images/71995/71995701056e64a7a5385f5d7a0c262264bdcd86" alt="QQ截图20131126220633.png 224855515.png"
用mongo 连接其中一台机器的27017 端口的mongod初始化Replica Sets“shard1”执行:
data:image/s3,"s3://crabby-images/e3249/e3249c6adda593a7e8e3137f4ff22ced28380b3f" alt="QQ截图20131126220633.png 232313903.png"
配置shard2所用到的Replica Sets
在Server A 上:
data:image/s3,"s3://crabby-images/e526f/e526f30d6dd59b8d981be575fc79d6c784ed1d52" alt="QQ截图20131127210955.png 211014213.png"
在Server B 上:
data:image/s3,"s3://crabby-images/ea16a/ea16a5a77afb2b25f620c780bcb6ed2845e1aea6" alt="QQ截图20131127210955.png 211140565.png"
在Server C 上:
data:image/s3,"s3://crabby-images/10b81/10b812fc7ed9fc1389e72cfc3a2f36cacc77039d" alt="QQ截图20131127210955.png 211205307.png"
用mongo 连接其中一台机器的27018 端口的mongod,初始化Replica Sets “shard2”,执行:
data:image/s3,"s3://crabby-images/45a8a/45a8a6e726274dbc41d51ca124e097336b2cf4ea" alt="QQ截图20131127210955.png 211620854.png"
配置3 台Config Server
在Server A、B、C上执行:
data:image/s3,"s3://crabby-images/3db18/3db18d5b3b38126169ba6b6b0cf3e5655e3614df" alt="QQ截图20131127210955.png 212106298.png"
配置3 台Route Process
在Server A、B、C上执行:
data:image/s3,"s3://crabby-images/e35ff/e35ffc24fd05f4e5b8367d1f62c354298497aa1d" alt="QQ截图20131127210955.png 212840826.png"
配置Shard Cluster
data:image/s3,"s3://crabby-images/9b71a/9b71ae260d63315bb08561d93d88b5f12d3d8819" alt="QQ截图20131127210955.png 213355138.png"
激活数据库及集合的分片
data:image/s3,"s3://crabby-images/de943/de9430c721d2897bce3156effd92aac7c69ad1a6" alt="QQ截图20131127210955.png 213620485.png"
验证Sharding正常工作
连接到其中一台机器的端口30000 的mongos 进程,并切换到test 数据库,以便添加测试数据
data:image/s3,"s3://crabby-images/a90a1/a90a117b4d3fbe580663bdfcf2e5919362ca40f7" alt="QQ截图20131127210955.png 214155640.png"
data:image/s3,"s3://crabby-images/54701/54701531fe66bf5dfcd053eb8fd50b4dcaaa016d" alt="QQ截图20131127210955.png 214240285.png"
可以看到Sharding搭建成功了,跟我们期望的结果一致,至此我们就将Replica Sets与Sharding
结合的架构也学习完毕了。
本文出自 “phper-每天一点点~” 博客,请务必保留此出处http://janephp.blog.51cto.com/4439680/1332140