7.5 KiB
title | description | weight | keywords | aliases | owner | test | status | ||||
---|---|---|---|---|---|---|---|---|---|---|---|
使用 MeshConfig 和 Pod 注解配置链路追踪 | 如何使用 MeshConfig 和 Pod 注解配置链路追踪。 | 3 |
|
|
istio/wg-policies-and-telemetry-maintainers | no | Beta |
{{< boilerplate telemetry-tracing-tips >}}
Istio 提供了配置高级链路追踪选项的能力,例如采样率和向报告的 span 中添加自定义标签。
开始之前
可用的链路追踪配置
您可以在 Istio 中配置以下链路追踪选项:
-
对生成追踪数据的请求按一定百分比进行随机采样。
-
请求路径的最大长度,之后路径将被截断报告。如果您在入口网关收集追踪信息, 这对于限制链路追踪的数据存储特别有用。
-
在 span 中添加自定义标签。这些标签可以基于静态文字添加请求标头中的值、环境值或字段。 这可以用来在特定于您的环境的 span 中注入其他信息。
有两种方法可以配置链路追踪选项:
-
全局地,通过
MeshConfig
选项。 -
基于每个 Pod 的注释,用于特定工作负载的定制。
{{< warning >}} 为了使新的链路追踪配置对其中任何一个 Pod 生效,您需要重新启动注入 Istio 代理的 Pod。
为链路追踪配置而添加的任何 Pod 注解都会覆盖全局设置。为了保留全局设置, 您应该将它们从全局网格配置复制到 Pod 注解中,并进行特定于工作负载的定制。 特别是要确保注解中始终提供链路追踪后端的地址,以确保正确地报告工作负载的追踪信息。 {{< /warning >}}
安装
使用这些特性为在您的环境中管理链路追踪提供了新的可能性。
在本例中,我们将对所有追踪进行采样,并添加一个名为 clusterID
的标签,使用
ISTIO_META_CLUSTER_ID
环境变量注入到您的 Pod 中(只使用该值的前 256 个字符)。
{{< text bash >}} $ cat < ./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 {{< /text >}}
使用 MeshConfig 进行链路追踪设置
所有追踪选项都可以通过 MeshConfig
全局配置。
为了简化配置,建议创建一个可以传递给 istioctl install -f
命令的 YAML 文件。
{{< text 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 {{< /text >}}
使用 proxy.istio.io/config
注解配置链路追踪
您可以添加 proxy.istio.io/config
注解到 Pod 元数据规约中,以覆盖任何网格范围的链路追踪配置。
例如,要修改 Istio 附带的 curl
Deployment,您需要在 samples/curl/curl.yaml
中添加以下内容:
{{< text 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: ... {{< /text >}}
自定义
自定义链路追踪采样
采样率选项可用于控制向链路追踪系统报告的请求的百分比, 这应该根据网格中的通信量和想要收集的追踪数据量进行配置, 默认值为 1%。
{{< warning >}}
以前,推荐的方法是在网格设置期间更改 values.pilot.traceSampling
设置,或在
istiod Deployment 中更改 PILOT_TRACE_SAMPLE
环境变量。
虽然这种改变抽样的方法仍然有效,但强烈建议改用以下方法。 {{< /warning >}}
要将默认随机抽样修改为 50,请在 tracing.yaml
文件中添加以下选项:
{{< text yaml >}} apiVersion: install.istio.io/v1alpha1 kind: IstioOperator spec: meshConfig: enableTracing: true defaultConfig: tracing: sampling: 50 {{< /text >}}
采样率应在 0.0 到 100.0 的范围内,精度为 0.01。 例如,要最终每 10000 个请求中的 5 个,使用 0.05 作为这里的值。
定制追踪标签
可以根据文字、环境变量和客户端请求标头向 span 中添加自定义标签, 以便在 span 中提供特定于您的环境的额外信息。
{{< warning >}} 可以添加的自定义标签的数量没有限制,但是标签名称必须是唯一的。 {{< /warning >}}
您可以使用下面三个受支持的选项中的任何一个来定制标签。
-
Literal 表示添加到每个 span 的静态值。
{{< text yaml >}} apiVersion: install.istio.io/v1alpha1 kind: IstioOperator spec: meshConfig: enableTracing: true defaultConfig: tracing: custom_tags: my_tag_literal: literal: value: {{< /text >}}
-
在从工作负载代理环境变量填充自定义标签的值时,可以使用环境变量。
{{< text yaml >}} apiVersion: install.istio.io/v1alpha1 kind: IstioOperator spec: meshConfig: enableTracing: true defaultConfig: tracing: custom_tags: my_tag_env: environment: name: <ENV_VARIABLE_NAME> defaultValue: # 可选 {{< /text >}}
{{< warning >}} 为了添加基于环境变量的自定义标签,您必须修改根 Istio 系统命名空间中的
istio-sidecar-injector
ConfigMap。 {{< /warning >}} -
客户端请求头选项可用于填充来自传入客户端请求头的标签值。
{{< text yaml >}} apiVersion: install.istio.io/v1alpha1 kind: IstioOperator spec: meshConfig: enableTracing: true defaultConfig: tracing: custom_tags: my_tag_header: header: name: defaultValue: # 可选 {{< /text >}}
自定义链路追踪标签长度
默认情况下,HttpUrl
span 标签中包含的请求路径的最大长度是 256。
要修改此最大长度,请将以下内容添加到您的 tracing.yaml
文件。
{{< text yaml >}} apiVersion: install.istio.io/v1alpha1 kind: IstioOperator spec: meshConfig: enableTracing: true defaultConfig: tracing: max_path_tag_length: {{< /text >}}