使用 MeshConfig 和 Pod 注解配置链路追踪

Istio 提供了配置高级链路追踪选项的能力,例如采样率和向报告的 span 中添加自定义标签。 采样是一个 Beta 级别特性,但是添加自定义标签和追踪的标签长度会考虑在本版本中开发。

开始之前

  1. 确保您的应用程序按照此处所述传输链路追踪的标头。

  2. 遵循位于集成章节下关于链路追踪的安装指南, 根据您喜欢的追踪后端安装适当的插件并且配置您的 Istio 代理以将追踪信息发送到部署的追踪后端中。

可用的链路追踪配置

您可以在 Istio 中配置以下链路追踪选项:

  1. 对生成追踪数据的请求按一定百分比进行随机采样。

  2. 请求路径的最大长度,之后路径将被截断报告。如果您在入口网关收集追踪信息, 这对于限制链路追踪的数据存储特别有用。

  3. 在 span 中添加自定义标签。这些标签可以基于静态文字添加请求标头中的值、环境值或字段。 这可以用来在特定于您的环境的 span 中注入其他信息。

有两种方法可以配置链路追踪选项:

  1. 全局通过 MeshConfig 选项。

  2. 用于工作负载特定定制的每个 Pod 注解。

安装

使用这些特性为在您的环境中管理链路追踪提供了新的可能性。

在本例中,我们将对所有追踪进行采样,并添加一个名为 clusterID 的标签,使用 ISTIO_META_CLUSTER_ID 环境变量注入到您的 Pod 中(只使用该值的前 256 个字符)。

$ cat <<EOF > ./tracing.yaml
apiVersion: install.istio.io/v1alpha1
kind: IstioOperator
spec:
  meshConfig:
    enableTracing: true
    defaultConfig:
      tracing:
        sampling: 100.0
        max_path_tag_length: 256
        custom_tags:
          clusterID:
            environment:
              name: ISTIO_META_CLUSTER_ID
EOF
$ istioctl install -f ./tracing.yaml

使用 MeshConfig 进行链路追踪设置

所有追踪选项都可以通过 MeshConfig 全局配置。 为了简化配置,建议创建一个可以传递给 istioctl install -f 命令的 YAML 文件。

cat <<'EOF' > tracing.yaml
apiVersion: install.istio.io/v1alpha1
kind: IstioOperator
spec:
  meshConfig:
    enableTracing: true
    defaultConfig:
      tracing:
        sampling: 10
        custom_tags:
          my_tag_header:
            header:
              name: host
EOF

使用 proxy.istio.io/config 注解配置链路追踪

您可以添加 proxy.istio.io/config 注解到 Pod 元数据规约中,以覆盖任何网格范围的链路追踪配置。 例如,要修改 Istio 附带的 curl Deployment,您需要在 samples/curl/curl.yaml 中添加以下内容:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: curl
spec:
  ...
  template:
    metadata:
      ...
      annotations:
        ...
        proxy.istio.io/config: |
          tracing:
            sampling: 10
            custom_tags:
              my_tag_header:
                header:
                  name: host
    spec:
      ...

自定义链路追踪采样

采样率选项可用于控制向链路追踪系统报告的请求的百分比, 这应该根据网格中的通信量和想要收集的追踪数据量进行配置, 默认值为 1%。

要将默认随机抽样修改为 50,请在 tracing.yaml 文件中添加以下选项:

apiVersion: install.istio.io/v1alpha1
kind: IstioOperator
spec:
  meshConfig:
    enableTracing: true
    defaultConfig:
      tracing:
        sampling: 50

采样率应在 0.0 到 100.0 的范围内,精度为 0.01。 例如,要最终每 10000 个请求中的 5 个,使用 0.05 作为这里的值。

定制追踪标签

可以根据文字、环境变量和客户端请求标头向 span 中添加自定义标签, 以便在 span 中提供特定于您的环境的额外信息。

您可以使用下面三个受支持的选项中的任何一个来定制标签。

  1. Literal 表示添加到每个 span 的静态值。

    apiVersion: install.istio.io/v1alpha1
    kind: IstioOperator
    spec:
      meshConfig:
        enableTracing: true
        defaultConfig:
          tracing:
            custom_tags:
              my_tag_literal:
                literal:
                  value: <VALUE>
  2. 在从工作负载代理环境变量填充自定义标签的值时,可以使用环境变量。

    apiVersion: install.istio.io/v1alpha1
    kind: IstioOperator
    spec:
      meshConfig:
        enableTracing: true
        defaultConfig:
          tracing:
            custom_tags:
              my_tag_env:
                environment:
                  name: <ENV_VARIABLE_NAME>
                  defaultValue: <VALUE>      # 可选
  3. 客户端请求头选项可用于填充来自传入客户端请求头的标签值。

    apiVersion: install.istio.io/v1alpha1
    kind: IstioOperator
    spec:
      meshConfig:
        enableTracing: true
        defaultConfig:
          tracing:
            custom_tags:
              my_tag_header:
                header:
                  name: <CLIENT-HEADER>
                  defaultValue: <VALUE>      # 可选

自定义链路追踪标签长度

默认情况下,HttpUrl span 标签中包含的请求路径的最大长度是 256。 要修改此最大长度,请将以下内容添加到您的 tracing.yaml 文件。

apiVersion: install.istio.io/v1alpha1
kind: IstioOperator
spec:
  meshConfig:
    enableTracing: true
    defaultConfig:
      tracing:
        max_path_tag_length: <VALUE>
这些信息有用吗?
您是否有更多建议和改进意见?

感谢您的反馈!