获取 /api/atlas/v1.0/groups/{groupId}/processes/{processId}/performanceAdvisor/suggestedIndexes

返回性能优化顾问建议的索引。Performance Advisor 会监控 MongoDB 认为其速度缓慢的查询,并建议使用新索引来提高查询性能。

角色要求
  • 项目只读

路径参数

  • groupId 字符串 必需

    用于标识项目的唯一 24-十六进制数字字符串。 使用 /groups 端点检索身份验证的用户有权访问权限的所有项目。

    注意:群组和项目是同义词。您的群组 ID 与项目 ID 相同。对于现有群组,群组/项目 ID 保持不变。资源和相应的端点使用“群组”一词。

    格式应符合以下模式:^([a-f0-9]{24})$

  • processId 字符串 必需

    为 MongoDB 进程提供服务的主机和端口的组合。主机必须是运行 MongoDB 进程(mongodmongos)的主机的主机名、FQDN、IPv4 地址或 IPv6 地址。该端口必须是 MongoDB 进程侦听请求的 IANA 端口。

    格式应符合以下模式:^([0-9]{1,3}\.){3}[0-9]{1,3}|([0-9a-f]{1,4}\:){7}([0-9a-f]{1,4})|(([a-z0-9]+\.){1,10}[a-z]+)?(\:[0-9]{4,5})$

查询参数

  • envelope 布尔

    指示应用程序是否将响应包装在envelope JSON 对象中的标志。某些 API 客户端无法访问 HTTP 响应标头或状态代码。要修复此问题,请在查询中设置 Envelope=true。返回结果列表的端点将结果对象用作 envelope。应用程序将状态参数添加到响应正文中。

    默认值为false

  • includeCount 布尔

    指示响应是否返回响应中的列项总数 (totalCount) 的标志。

    默认值为true

  • itemsPerPage 整型

    响应每页返回的列项数。

    最小值为 1,最大值为 500。默认值为 100

  • pageNum 整型

    显示响应返回的当前总对象集的页面编号。

    最小值为 1。默认值为 1

  • pretty 布尔

    指示响应正文是否应采用 prettyprint 格式的标记。

    默认值为false

    Prettyprint
  • duration integer(int64)

    查询在集群的托管命名空间中查找建议索引的时间长度。此参数以毫秒为单位。

    • 如果不指定 since 参数,则端点将返回涵盖当前时间之前持续时间的数据。
    • 如果您既不指定 duration 也不指定 since 参数,该端点将返回过去 24 小时的数据。
  • namespaces array[string]

    从中检索建议索引的命名空间。命名空间由一个数据库和一个集合资源组成,写作 .: <database>.<collection>。要包含多个命名空间,请多次传递该参数,并在每个命名空间之间用与号 (&) 分隔。省略此参数可返回所有命名空间的结果。

  • nExamples integer(int64)

    从建议的索引中受益的示例查询的最大数量。

    默认值为5

  • nIndexes integer(int64)

    指示要建议的最大索引的数字。

  • since integer(int64)

    查询检索建议索引的日期和时间。该参数以自 UNIX 纪元以来经过的毫秒数表示其值。

    • 如果不指定持续时间参数,端点将返回从 since 值到当前时间的数据。
    • 如果您既不指定 duration 也不指定 since 参数,该端点将返回过去 24 小时的数据。

    最小值为 1199145600000

响应

  • 200 application/json

    正常

    隐藏响应属性 显示响应属性 对象
    • 形状 大量[对象]

      Performance Advisor建议的查询谓词、排序和投影的列表。

      隐藏形状属性 显示形状属性 对象
      • avgMs integer(int64)

        与此形状匹配的已检查查询的平均持续时间(以毫秒为单位)。

      • 数数 integer(int64)

        已检查的与此形状匹配的查询数量。

      • id 字符串

        Unique 24-hexadecimal digit string that identifies this shape. This string exists only for the duration of this API request.

        格式应符合以下模式:^([a-f0-9]{24})$

      • infficiencyScore integer(int64)

        查询返回的每个文档的平均读取文档数。

        了解查询效率低下...
      • namespace 字符串

        人类可读标签,用于标识指定托管上的命名空间。资源将此参数值表示为 <database>.<collection>

      • 操作 大量[对象]

        List that contains specific about individual queries.

        隐藏操作属性 显示操作属性 对象
        • 谓词 大量[对象]

          List that contains the search criteria that the query uses. To use the values in key-value pairs in these predicates requires Project Data Access Read Only permissions or greater. Otherwise, MongoDB Cloud redacts these values.

          List that contains the search criteria that the query uses. To use the values in key-value pairs in these predicates requires Project Data Access Read Only permissions or greater. Otherwise, MongoDB Cloud redacts these values.

          List that contains the search criteria that the query uses. To use the values in key-value pairs in these predicates requires Project Data Access Read Only permissions or greater. Otherwise, MongoDB Cloud redacts these values.

        • stats 对象

          此资源返回的有关指定查询的详细信息。

          隐藏统计属性 显示统计属性 对象
          • ms integer(int64)

            查询在集群的托管命名空间中找到建议索引的时间长度。此参数以毫秒为单位。该参数与持续时间查询参数有关。

          • nReturned integer(int64)

            查询返回的结果数。

          • nScanned integer(int64)

            查询读取的文档数量。

          • Typescript integer(int64)

            查询建议索引的日期和时间。此参数以自 UNIX 纪元以来经过的秒数表示其值。此参数与“since”查询参数相关。

            UNIX Epoch
    • suggestIndexes 大量[对象]

      包含文档的列表,这些文档附带Performance Advisor建议的索引信息。

      隐藏 suggestIndexes 属性 显示 suggestIndexes 属性 对象
      • avgObjSize number(double)

        此索引的集合中对象的平均大小。

      • id 字符串

        标识此索引的唯一 24-十六进制数字字符串。

        格式应符合以下模式:^([a-f0-9]{24})$

      • 影响 array[string]

        包含唯一的 24-十六进制字符串的列表,该字符串标识此响应中性能Performance Advisor建议的查询形状。

      • 索引(index) 大量[对象]

        包含指定索引中的键及其排序顺序的文档的列表。

        隐藏索引属性 显示索引属性 对象

        一个索引键与其排序顺序配对。值为 1 表示升序排序顺序。值为 -1 表示降序排序。具有多个键的索引中的键的显示顺序与其在索引中的显示顺序相同。

        • * integer(int32) additionalProperties

          一个索引键与其排序顺序配对。值为 1 表示升序排序顺序。值为 -1 表示降序排序。具有多个键的索引中的键的显示顺序与其在索引中的显示顺序相同。

          值为 1-1

      • namespace 字符串

        人类可读标签,用于标识指定托管上的命名空间。资源将此参数值表示为 <database>.<collection>

      • 重量 number(double)

        建议的索引提供的预计性能改进。该值对应于Performance Advisor用户界面中的影响。

  • 401 application/json

    未经授权。

    隐藏响应属性 显示响应属性 对象
    • badRequestDetail 对象

      错误请求详情。

      隐藏 BadRequestDetail 属性 显示 BadRequestDetail 属性 对象
      • 字段 大量[对象]

        描述客户端请求中的所有违规行为。

        隐藏字段属性 显示字段属性 对象
        • 描述 字符串 必需

          关于请求元素错误的原因的描述。

        • 字段 字符串 必需

          指向请求正文中字段的路径。

    • 详细信息 字符串

      描述导致每种错误类型的具体条件或原因。

    • 错误 integer(int32) 必需

      与此错误一起返回的 HTTP 状态代码。

      外部文档
    • 错误代码 字符串 必需

      返回此错误时附带应用程序错误代码。

    • 参数 大量[对象]

      用于提供更多错误信息的参数。

    • 原因 字符串

      随此错误返回的应用程序错误消息。

  • 403 application/json

    Forbidden.

    隐藏响应属性 显示响应属性 对象
    • badRequestDetail 对象

      错误请求详情。

      隐藏 BadRequestDetail 属性 显示 BadRequestDetail 属性 对象
      • 字段 大量[对象]

        描述客户端请求中的所有违规行为。

        隐藏字段属性 显示字段属性 对象
        • 描述 字符串 必需

          关于请求元素错误的原因的描述。

        • 字段 字符串 必需

          指向请求正文中字段的路径。

    • 详细信息 字符串

      描述导致每种错误类型的具体条件或原因。

    • 错误 integer(int32) 必需

      与此错误一起返回的 HTTP 状态代码。

      外部文档
    • 错误代码 字符串 必需

      返回此错误时附带应用程序错误代码。

    • 参数 大量[对象]

      用于提供更多错误信息的参数。

    • 原因 字符串

      随此错误返回的应用程序错误消息。

  • 404 application/json

    未找到。

    隐藏响应属性 显示响应属性 对象
    • badRequestDetail 对象

      错误请求详情。

      隐藏 BadRequestDetail 属性 显示 BadRequestDetail 属性 对象
      • 字段 大量[对象]

        描述客户端请求中的所有违规行为。

        隐藏字段属性 显示字段属性 对象
        • 描述 字符串 必需

          关于请求元素错误的原因的描述。

        • 字段 字符串 必需

          指向请求正文中字段的路径。

    • 详细信息 字符串

      描述导致每种错误类型的具体条件或原因。

    • 错误 integer(int32) 必需

      与此错误一起返回的 HTTP 状态代码。

      外部文档
    • 错误代码 字符串 必需

      返回此错误时附带应用程序错误代码。

    • 参数 大量[对象]

      用于提供更多错误信息的参数。

    • 原因 字符串

      随此错误返回的应用程序错误消息。

  • 429 application/json

    请求过多。

    隐藏响应属性 显示响应属性 对象
    • badRequestDetail 对象

      错误请求详情。

      隐藏 BadRequestDetail 属性 显示 BadRequestDetail 属性 对象
      • 字段 大量[对象]

        描述客户端请求中的所有违规行为。

        隐藏字段属性 显示字段属性 对象
        • 描述 字符串 必需

          关于请求元素错误的原因的描述。

        • 字段 字符串 必需

          指向请求正文中字段的路径。

    • 详细信息 字符串

      描述导致每种错误类型的具体条件或原因。

    • 错误 integer(int32) 必需

      与此错误一起返回的 HTTP 状态代码。

      外部文档
    • 错误代码 字符串 必需

      返回此错误时附带应用程序错误代码。

    • 参数 大量[对象]

      用于提供更多错误信息的参数。

    • 原因 字符串

      随此错误返回的应用程序错误消息。

  • 500 application/json

    内部服务器错误。

    隐藏响应属性 显示响应属性 对象
    • badRequestDetail 对象

      错误请求详情。

      隐藏 BadRequestDetail 属性 显示 BadRequestDetail 属性 对象
      • 字段 大量[对象]

        描述客户端请求中的所有违规行为。

        隐藏字段属性 显示字段属性 对象
        • 描述 字符串 必需

          关于请求元素错误的原因的描述。

        • 字段 字符串 必需

          指向请求正文中字段的路径。

    • 详细信息 字符串

      描述导致每种错误类型的具体条件或原因。

    • 错误 integer(int32) 必需

      与此错误一起返回的 HTTP 状态代码。

      外部文档
    • 错误代码 字符串 必需

      返回此错误时附带应用程序错误代码。

    • 参数 大量[对象]

      用于提供更多错误信息的参数。

    • 原因 字符串

      随此错误返回的应用程序错误消息。

GET /API/Atlas/v1.0/groups/{groupId}/processes/{processId}/performanceAdvisor/suggestedIndexes
curl \
 --request GET 'https://cloud.mongodb.com/api/atlas/v1.0/groups/32b6e34b3d91647abb20e7b8/processes/{processId}/performanceAdvisor/suggestedIndexes' \
 --header "Authorization: Bearer $ACCESS_TOKEN"
响应示例 (200)
{
  "shapes": [
    {
      "avgMs": 42,
      "count": 42,
      "id": "32b6e34b3d91647abb20e7b8",
      "inefficiencyScore": 42,
      "namespace": "string",
      "operations": [
        {
          "predicates": [
            {}
          ],
          "stats": {
            "ms": 42,
            "nReturned": 42,
            "nScanned": 42,
            "ts": 42
          }
        }
      ]
    }
  ],
  "suggestedIndexes": [
    {
      "avgObjSize": 42.0,
      "id": "32b6e34b3d91647abb20e7b8",
      "impact": [
        "string"
      ],
      "index": [
        {
          "additionalProperty1": 1,
          "additionalProperty2": 1
        }
      ],
      "namespace": "string",
      "weight": 42.0
    }
  ]
}
响应示例 (401)
{
  "detail": "(This is just an example, the exception may not be related to this endpoint)",
  "error": 401,
  "errorCode": "NOT_ORG_GROUP_CREATOR",
  "reason": "Unauthorized"
}
响应示例 (403)
{
  "detail": "(This is just an example, the exception may not be related to this endpoint)",
  "error": 403,
  "errorCode": "CANNOT_CHANGE_GROUP_NAME",
  "reason": "Forbidden"
}
响应示例 (404)
{
  "detail": "(This is just an example, the exception may not be related to this endpoint) Cannot find resource AWS",
  "error": 404,
  "errorCode": "RESOURCE_NOT_FOUND",
  "reason": "Not Found"
}
响应示例 (429)
{
  "detail": "(This is just an example, the exception may not be related to this endpoint)",
  "error": 429,
  "errorCode": "RATE_LIMITED",
  "reason": "Too Many Requests"
}
响应示例 (500)
{
  "detail": "(This is just an example, the exception may not be related to this endpoint)",
  "error": 500,
  "errorCode": "UNEXPECTED_ERROR",
  "reason": "Internal Server Error"
}