配置 Azure Monitor OpenTelemetry

本文介绍 Azure Monitor OpenTelemetry 发行版的配置设置。

连接字符串

Application Insights 中的连接字符串定义了用于发送遥测数据的目标位置。

要设置连接字符串,请参阅连接字符串

设置云角色名称和云角色实例

对于支持的语言,Azure Monitor OpenTelemetry 发行版会自动检测资源上下文,并为组件的云角色名称和云角色实例属性提供默认值。 但是,可能需要将默认值替代为对团队有意义的值。 云角色名称值以节点下面的名称出现在应用程序映射上。

若要设置云角色名称,请参阅云角色名称

若要设置云角色实例,请参阅云角色实例

启用采样

可能需要启用采样以减少数据引入量,从而降低成本。 Azure Monitor 提供自定义固定速率采样器,该采样器使用采样率填充事件,Application Insights 会将其转换为 ItemCount固定速率采样器可确保准确的体验和事件计数。 采样器旨在跨服务保留跟踪,并可与较旧的 Application Insights 软件开发工具包 (SDK) 互操作。 有关详细信息,请参阅详细了解采样

备注

指标和日志不受采样影响。

自 3.4.0 起开始提供速率限制采样,现在为默认设置。 有关采样的详细信息,请参阅 Java 采样

提示

使用固定比率/百分比采样时,如果你不确定如何设置采样率,请从 5%(即 0.05 采样率)开始,并根据失败和性能窗格中显示的操作准确度调整比率。 通常情况下,采样率越高,准确度越高。 但是,任何采样都会影响准确度,因此我们建议对不受采样影响的 OpenTelemetry 指标发出警报。

实时指标

实时指标提供实时分析仪表板,用于深入了解应用程序活动和性能。

默认情况下会启用实时指标体验。

有关 Java 配置的详细信息,请参阅配置选项:Azure Monitor Application Insights for Java

启用 Microsoft Entra ID(前 Azure AD)身份验证

你可能需要启用 Microsoft Entra 身份验证,以便更安全地连接到 Azure,从而防止未经授权的遥测数据引入你的订阅。

有关 Java 的详细信息,请参阅 Java 补充文档

脱机存储和自动重试

为了提高可靠性和复原能力,基于 OpenTelemetry 的 Azure Monitor 产品/服务默认在应用程序与 Application Insights 失去连接时写入脱机/本地存储。 这会将应用程序遥测数据保存到磁盘,并定期尝试再次发送遥测数据,最长持续时间为 48 小时。 在高负载应用程序中,遥测偶尔会出于两个原因而被删除。 首先,当允许的时间超过时;其次,当文件大小超过最大值或 SDK 没有机会清除文件时。 如果需要选择,产品会保存较新的事件,而不是较旧的事件。 了解详细信息

在 Java 中无法配置脱机存储和自动重试。

有关可用配置的完整列表,请参阅配置选项

启用 OTLP 导出器

你可能想要启用 OpenTelemetry 协议 (OTLP) 导出器和 Azure Monitor 导出器,以将遥测数据发送到两个位置。

备注

为方便起见,只展示了 OTLP 导出器。 我们并未正式支持使用 OTLP 导出器或是其下游的任何组件或第三方体验。

有关 Java 的详细信息,请参阅 Java 补充文档

OpenTelemetry 配置

使用 Azure Monitor OpenTelemetry 发行版时,可以通过环境变量访问以下 OpenTelemetry 配置。

有关 Java 的详细信息,请参阅 Java 补充文档

编辑 URL 查询字符串

若要编辑 URL 查询字符串,请禁用查询字符串收集。 如果使用 SAS 令牌调用 Azure 存储,建议使用此设置。

将以下内容添加到 applicationinsights.json 配置文件:

{
  "preview": {
    "processors": [
      {
        "type": "attribute",
        "actions": [
          {
            "key": "url.query",
            "pattern": "^.*$",
            "replace": "REDACTED",
            "action": "mask"
          }
        ]
      },
      {
        "type": "attribute",
        "actions": [
          {
            "key": "url.full",
            "pattern": "[?].*$",
            "replace": "?REDACTED",
            "action": "mask"
          }
        ]
      }
    ]
  }
}