改进您的架构
模式是集群的架构,包括集合、索引和文档。 在开发过程的早期考虑模式设计。
您无法访问无服务器实例的 Schema Advisor 。
模式设计模式
您可以根据常用设计模式对模式进行建模。使用模式构建博客系列讨论了以下常用设计模式。
要了解数组运行良好的情况,请参阅以下设计模式:
使用属性模式处理具有唯一属性组合的数据,例如每部电影在一个国家/地区子集上映的电影数据。
使用存储桶模式处理紧密分组或连续的数据,例如时间跨度数据。
使用多态模式处理同一集合中不同形状的文档,例如多个运动项目的运动员记录。
要了解将工作集中的文档保持在可管理大小的策略,请参阅以下模式:
要了解如何将灵活数据模型整合到您的架构中,请参阅 MongoDB.live 2020 中的以下演示文稿:
通过 MongoDB 数据建模了解 MongoDB 中的实体关系及其实现示例。
通过高级模式设计模式了解您可以整合到模式的高级数据建模设计模式。
模式建议
Atlas 提供了两种方法来检测常见的模式设计问题,并建议遵循 MongoDB 的最佳实践进行修改:
性能优化顾问通过对最活跃的集合和查询运行缓慢的集合中的文档进行采样,为集群提供整体模式建议。
Atlas 用户界面通过对特定集合中的文档进行采样来为该集合提供模式建议。
要了解有关如何应用 Performance Advisor 或数据浏览器中提供的建议的更多信息,请参阅以下页面:
模式改进 | 建议理由 |
---|---|
您对数据执行了太多 $lookup 操作。请利用 MongoDB 的丰富架构模式将相关数据嵌入到单个集合中。 | |
您的文档包含具有多种元素的数组字段,这可能会降低查询性能。 | |
您的集合中包含不必要的索引,这会占用磁盘空间并降低写入性能。 | |
您的文档过大,可能会导致最频繁执行的查询变得缓慢,从而影响系统的性能表现。 | |
您的数据库中有大量的集合,这可能会导致不必要的磁盘空间使用量。 | |
您正在执行的查询依赖于低效的正则表达式匹配。利用使用 $search 聚合管道阶段的 Atlas Search 查询 。 |
模式建议限制
针对某个集合的模式建议部分是通过对该集合的文档进行随机抽样得出的。由于每次分析模式时都会进行采样,因此您可能会在不同时间看到针对同一集合的不同建议。
性能优化顾问会监控慢速查询以识别某些模式问题,即
$lookup
操作过多以及未利用索引进行区分大小写的正则表达式查询。如果集群未能始终如一地接收长时间运行的查询,则性能优化顾问可能不会建议该集群的所有潜在改进,也可能不会显示建议改进的所有原因。Performance Advisor根据
top
命令的输出分析 20 个最活跃的集合。如要查看特定集合的建议,请在 Atlas 用户界面中查看该集合。性能优化顾问和Atlas 用户界面都不提供针对时间序列集合的模式建议。