MongoDB分片概述

【引自SoulMio的博客】分片

在Mongodb里面存在另一种集群,就是分片技术,可以满足MongoDB数据量大量增长的需求。

当MongoDB存储海量的数据时,一台机器可能不足以存储数据,也可能不足以提供可接受的读写吞吐量。这时,我们就可以通过在多台机器上分割数据,使得数据库系统能存储和处理更多的数据。

为什么使用分片

  • 复制所有的写入操作到主节点
  • 延迟的敏感数据会在主节点查询
  • 单个副本集限制在12个节点
  • 当请求量巨大时会出现内存不足。
  • 本地磁盘不足
  • 垂直扩展价格昂贵

MongoDB分片

下图展示了在MongoDB中使用分片集群结构分布: 

 

 

 

上图中主要有如下所述三个主要组件:

  • Shard:

用于存储实际的数据块,实际生产环境中一个shard server角色可由几台机器组个一个replica set承担,防止主机单点故障

  • Config Server:

mongod实例,存储了整个 ClusterMetadata,其中包括 chunk信息。

  • Query Routers:

前端路由,客户端由此接入,且让整个集群看上去像单一数据库,前端应用可以透明使用。

分片实例

192.168.1.100 : mongos

192.168.1.110 : config server

192.168.1.101 : Shard1

192.168.1.102 : Shard2

以上四个主机上都以安装mongodb数据库。

一.配置config server

编辑配置文件mongod.conf:

  1. vim /etc/mongod.conf 

添加如下并启用config server服务:

  1. configsvr=true 

重新启动mongodb服务:

  1. service mongod restart 

注:默认监听27019端口。也可以使用如下命令启动mongod进程。

  1. # mongod --configsvr --dbpath <path> --port <port> 

此时,默认端口由27017变为27019: 

 

 

 

二.配置mongos实例

安装mongos:

  1. yum install mongodb-org-mongos-2.6.1-1.x86_64.rpm 

启动mongos:

  1. mongos --configdb=192.168.1.110 --fork --logpath=/var/log/mongodb/mongos.log 

注:mongos属于轻量级应用,完全可以与其它服务运行于同一节点;启动时,需要为mongos实例指明各config服务器的访问地址;

默认情况下,mongos监听于27017端口;可以使用如下命令启动mongos实例。

  1. # mongos --configdb <config server hostnames((IP|Hostname):Port)> 

也可以直接编辑配置文件:

1、注释dbpath指令;

2、添加configdb指令,并指定config服务器的地址;

而后使用如下命令启动mongos实例:

  1. # mongos -f /etc/mongod.conf 

登录mongos并配置shard节点:

  1. mongo --host 192.168.1.100 
  2. mongos> sh.addShard("192.168.1.101"
  3. "shardAdded" : "shard0000""ok" : 1 } 
  4. mongos> sh.addShard("192.168.1.102"
  5. "shardAdded" : "shard0001""ok" : 1 }  

查看shard状态:

  1. mongos> sh.status() 
  2. --- Sharding Status ---  
  3.   sharding version: { 
  4. "_id" : 1, 
  5. "version" : 4, 
  6. "minCompatibleVersion" : 4, 
  7. "currentVersion" : 5, 
  8. "clusterId" : ObjectId("58d4bd8a102ad4bdad74aa1d"
  9.   shards: 
  10. {  "_id" : "shard0000",  "host" : "192.168.1.101:27017" } 
  11. {  "_id" : "shard0001",  "host" : "192.168.1.102:27017" } 
  12.   databases: 
  13. {  "_id" : "admin",  "partitioned" : false,  "primary" : "config" }  

启动sharding功能:

  1. mongos> sh.enableSharding("testdb"); 
  2. "ok" : 1 }  

注:mongodb的shard功能实现于collection级别,但若要在collection上启动shard,还需要事先其相关的数据库上启用之。在数据库上启用shard功能后,MongoDB会为其指定一个主shard。

启用过程需要mongos实例上实现,可以使用sh.enableSharding()方法,也可以使用db.runCommand()的“enableSharding命令,它们的使用格式分别如下所示:

  1. sh.enableSharding("<database>"
  2. db.runCommand( { enableSharding: <database> } )  

此时,再次查看shard状态为:

  1. mongos> sh.status() 
  2. --- Sharding Status ---  
  3.   sharding version: { 
  4. "_id" : 1, 
  5. "version" : 4, 
  6. "minCompatibleVersion" : 4, 
  7. "currentVersion" : 5, 
  8. "clusterId" : ObjectId("58d4bd8a102ad4bdad74aa1d"
  9.   shards: 
  10. {  "_id" : "shard0000",  "host" : "192.168.1.101:27017" } 
  11. {  "_id" : "shard0001",  "host" : "192.168.1.102:27017" } 
  12.   databases: 
  13. {  "_id" : "testdb",  "partitioned" : true,  "primary" : "shard0000" }  

测试:

在collection上进行sharding:

  1. mongos> sh.shardCollection("testdb.student",{"age":1}) 
  2. "collectionsharded" : "testdb.student""ok" : 1 }  

插入数据:

  1. mongos> for (i=1;i<=100000;i++) db.student.insert({name:"student"+i,age:(i%120),classes:"class+(i%10)"}); 
  2. WriteResult({ "nInserted" : 1 })  

此时我们再次查看sharding状态如下:

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/262251.html<

(0)
运维的头像运维
上一篇2025-05-04 00:30
下一篇 2025-05-04 00:32

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注