5步优化MongoDB以及其它数据库

Jared Rosoff 在 Scale Out Camp 发表了一篇简洁、有效、有趣和令人信服的《8 分钟 MongoDB 教程》描述了如何进行 MongoDB 优化。

文中的方法不仅限于 MongoDB,还可应用到绝大多数数据库,比如查询优化、找出你的热数据、调整文件系统、选择正确的磁盘设备、分片。下面分别对 5 种策略进行说明:

查询优化:用 B-tree 搜索的速度显然比全表扫描来的快,所以你需要优化你的查询语句。用 explain来分析你的查询语句,如果返回的结果现实这个查询用到了 cursor 那么它会是一个全表扫描,也就是说它会非常慢。分析有多少条记录会满足查询条件,以及查询会执行多长时间。改进的方法就是为其增加索引。不管你是有 1 台还是有 100 台服务器

找出你的热数据尺寸:在数据库前面使用 Memcached 其实挺可笑的,因为现在内存很便宜,你可以使用大量的内存来缓存数据库内容,MongoDB 就是这样干的。热数据 = 活跃记录 + 使用过的索引。在内存中命中数据是非常快的,而从磁盘获取数据就非常慢。假设你有上十亿的用户,但只有十万用户当前是活跃的,那么你的热数据尺寸就是十万条。你需要规划足够的内存来存放那十万条热数据,保证他们能够从内存而不是磁盘里读取,别忘了索引也是需要占用内存的。

[[190185]] 

调整文件系统:性能问题往往根源是在文件系统。比如 EXT3 已经过时了,请使用 EXT4、XFS 和其它高性能的文件系统。对于数据库来说并不需要每次访问都去更新文件,所以关掉文件的访问时间跟踪功能,不然会有很多不必要的磁盘写操作。在 EXT3 文件系统预分配一个 2GB 大小的文件是非常耗时的,因为它必须得在分配时完整初始化整个文件。

选择正确的磁盘设备:寻道时间是需要关注的问题,因为大多数时候磁盘的 IO 操作是随机的。寻道时间取决于机械臂在磁盘上来回移动的速度,磁盘的平均寻道操作能力是每秒钟能完成 200 次。高速磁盘之所以读取数据更快,是因为他们有更高的带宽容量,除此之外他们的寻道时间并没有区别。使用单个磁盘时,你可以获得每秒 200 次寻道;而使用 RAID 0(跨多个磁盘),3 块磁盘可以让你获得每秒 600 次的寻道速度;那么使用 RAID 10(镜像 + 跨越),6 块磁盘甚至能让你获得每秒 1200 次寻道。所以要考虑用 RAID 来进行优化。如今的 SSD 存储就更夸张了,一次寻道只要 0.1 毫秒,是机械磁盘的 50 倍,更适用于随机的读取操作。

分片:如果你的程序性能很差,索引又建的不正确,磁盘设备的速度也很慢,那么单点的性能也就非常差了。改善这种情况的方法就是用分片来做横向扩展,分片可以让你把系统负责分散到由更多机器组成的高可用的 replica sets 集群。数据将会按一定范围被切分成很多的区块,然后横向扩展到上百台服务器,上千次的写操作在被拆分后每台服务器只需要处理十来次操作。分片让横向扩展变得容易。

 

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

(0)
运维的头像运维
上一篇2025-05-23 12:08
下一篇 2025-05-23 12:10

相关推荐

  • 个人主题怎么制作?

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

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

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

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

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

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

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

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

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

    2025-11-20
    0

发表回复

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