MongoDB的设计模式策略

MongoDB是一项通用工具,但它也并非***。针对某些MongoDB不适用的场合,有时可选用设计模式来加以应对。

MongoDB是一个NoSQL文档数据库,在大多数情况下是一个相对理想的选择,即使是在其不适用的情况下,也仍然可以依靠下面所列举的这些设计模式来克服其局限性。

本文将针对我的另一篇文章《MongoDB的好坏恶》( MongoDB : The Good, The Bad, and the Ugly)中所提及的一些局限性,提供一个相对应的解决方案。

1. 查询命令分离模式

 

在副本集中职责被分离到不同的节点。最基本的***类节点可能也同时占据着首要地位,它只需要储存那些写入和更新所需的数据。而查询工作则交由第二类节点来执行。这一模式将提升首要节点服务器的写吞吐量,因为当写入一组对象时,需要更新及插入的数据量也随之减少,除此之外,二类节点也得益于较少的待更新数据和其自身所具有的为其工作量而优化的内存工作集。

2. 应用程序级事务模式

MongoDB不支持事务和文件内部锁定。然而,依据应用逻辑,应当保留queue用法。

  1. db.queue.insert( { _id : 123,   
  2.  
  3.   
  4.  
  5.     message : { },   
  6.  
  7.     locked : false,   
  8.  
  9.     tlocked : ISODate(),   
  10.  
  11.     try : 0 });   
  12.  
  13. var timerange = date.Now() - TIMECONSTANT;   
  14.  
  15. var doc = db.queue.findAndModify( { $or : [ { locked : false }, { locked : true, tlocked : { 
  16.  
  17. $lt : timerange } } ], { $set : { locked : true, tlocked : date.Now(), $inc : { try : 1 } } }   
  18.  
  19. );   
  20.  
  21. //do some processing   
  22.  
  23. db.queue.update( { _id : 123, try : doc.try }, { } );  

3. Bucketing模式

当文本含有一个不断增长的数组时,则使用Bucketing模式,例如指令。而指令线可能会扩展到超过文档大小的合理值。该模式经由编程方式处理,并通过公差计算触发。

  1. var TOLERANCE = 100;   
  2.  
  3.     for( recipient in msg.to) {   
  4.  
  5.         db.inbox.update( {   
  6.  
  7.             owner: msg.to[recipient], count: { $lt : TOLERANCE }, time : { $lt : Date.now() } },   
  8.  
  9. { $setOnInsert : { owner: msg.to[recipient], time : Date.now() },   
  10.  
  11. { $push: { "messages": msg }, $inc : { count : 1 } },   
  12.  
  13. { upsert: true } );  

4. 关系模式

有时,会有不能插入整个文档的情况,例如人体建模时,我们就可以使用该模式来建立关系。

  • 确定数据是否属于该文档,即二者间是否有关系。
  • 如果可能的话,特别是面对有用的独有(专属)数据时,插入文档。
  • 尽可能不参考id值。
  • 对关系中的有用部分进行反规范化处理。好的候选不会经常甚至从不更改值,并且颇为有用。
  • 关注反规范数据的更新和关系修复。
  1. {   
  2.  
  3.      _id : 1,   
  4.  
  5.     name : ‘Sam Smith’,   
  6.  
  7.     bio : ‘Sam Smith is a nice guy’,   
  8.  
  9.     best_friend : { id : 2, name : ‘Mary Reynolds’ },   
  10.  
  11.     hobbies : [ { id : 100, n :’Computers’ }, { id : 101, n : ‘Music’ } ]   
  12.  
  13. }   
  14.  
  15. {   
  16.  
  17.     _id : 2,   
  18.  
  19.     name : ‘Mary Reynolds’   
  20.  
  21.     bio : ‘Mary has composed documents in MongoDB’,   
  22.  
  23.     best_friend : { id : 1, name : ‘Sam Smith’ },   
  24.  
  25.     hobbies : [ { id : 101, n : ‘Music’ } ]   
  26.  
  27.  

5. 物化路径模式

 

在一个数据模型的树模式中,同一对象类型是该对象的子对象,这种情况下可以使用物化路径模型来以获取更高效的检索、查询。示例如下:

  1. { _id: "Books", path: null }   
  2.  
  3. { _id: "Programming", path: ",Books," }   
  4.  
  5. { _id: "Databases", path: ",Books,Programming," }   
  6.  
  7. { _id: "Languages", path: ",Books,Programming," }   
  8.  
  9. { _id: "MongoDB", path: ",Books,Programming,Databases," }   
  10.  
  11. { _id: "dbm", path: ",Books,Programming,Databases," }  

按字段路径查询树模式:

  1. db.collection.find().sort( { path: 1 } ) 

使用路径字段的常规表达来找出Programming的后代集:

  1. db.collection.find( { path: /,Programming,/ } ) 

在Books是top parent的情况下查询Books的后代集:

  1. db.collection.find( { path: /^,Books,/ } )  

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

(0)
运维的头像运维
上一篇2025-05-03 15:30
下一篇 2025-05-03 15:31

相关推荐

  • 个人主题怎么制作?

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

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

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

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

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

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

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

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

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

    2025-11-20
    0

发表回复

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