Linkerd2 使用外部 Prometheus 监控数据持久化实践
2025-05-21 15:26:00作者:齐添朝
背景介绍
在 Kubernetes 服务网格 Linkerd2 的监控方案中,可视化组件 linkerd-viz 默认会部署一个内置的 Prometheus 实例。然而,这个内置实例存在数据无法持久化的问题,当 Pod 重启后历史监控数据就会丢失。本文将详细介绍如何配置 Linkerd2 使用外部 Prometheus 实现监控数据的持久化存储。
核心问题分析
Linkerd2 的 linkerd-viz 组件提供了服务网格的可观测性功能,包括路由指标、服务拓扑等。这些功能依赖于 Prometheus 采集和存储的指标数据。默认情况下,linkerd-viz 会部署一个非持久化的 Prometheus 实例,这会导致:
- 历史监控数据无法保留
- 无法进行长期趋势分析
- 重启后所有指标数据丢失
解决方案实施
1. 部署外部 Prometheus
使用 Helm 部署一个持久化的 Prometheus 实例到 linkerd-viz 命名空间:
server:
podAnnotations:
linkerd.io/inject: enabled
global:
scrape_interval: 10s
scrape_timeout: 10s
evaluation_interval: 10s
service:
servicePort: 9090
persistentVolume:
size: 20Gi
serverFiles:
prometheus.yml:
scrape_configs:
- job_name: 'linkerd-controller'
kubernetes_sd_configs:
- role: pod
namespaces:
names:
- 'linkerd'
- 'linkerd-viz'
relabel_configs:
- source_labels:
- __meta_kubernetes_pod_container_port_name
action: keep
regex: admin-http
- source_labels: [__meta_kubernetes_pod_container_name]
action: replace
target_label: component
- job_name: 'linkerd-service-mirror'
kubernetes_sd_configs:
- role: pod
relabel_configs:
- source_labels:
- __meta_kubernetes_pod_label_linkerd_io_control_plane_component
- __meta_kubernetes_pod_container_port_name
action: keep
regex: linkerd-service-mirror;admin-http$
- source_labels: [__meta_kubernetes_pod_container_name]
action: replace
target_label: component
- job_name: 'linkerd-proxy'
kubernetes_sd_configs:
- role: pod
relabel_configs:
- source_labels:
- __meta_kubernetes_pod_container_name
- __meta_kubernetes_pod_container_port_name
- __meta_kubernetes_pod_label_linkerd_io_control_plane_ns
action: keep
regex: ^linkerd-proxy;linkerd-admin;linkerd$
- source_labels: [__meta_kubernetes_namespace]
action: replace
target_label: namespace
- source_labels: [__meta_kubernetes_pod_name]
action: replace
target_label: pod
- source_labels: [__meta_kubernetes_pod_label_linkerd_io_proxy_job]
action: replace
target_label: k8s_job
- action: labeldrop
regex: __meta_kubernetes_pod_label_linkerd_io_proxy_job
- action: labelmap
regex: __meta_kubernetes_pod_label_linkerd_io_proxy_(.+)
- action: labeldrop
regex: __meta_kubernetes_pod_label_linkerd_io_proxy_(.+)
- action: labelmap
regex: __meta_kubernetes_pod_label_linkerd_io_(.+)
- action: labelmap
regex: __meta_kubernetes_pod_label_(.+)
replacement: __tmp_pod_label_$1
- action: labelmap
regex: __tmp_pod_label_linkerd_io_(.+)
replacement: __tmp_pod_label_$1
- action: labeldrop
regex: __tmp_pod_label_linkerd_io_(.+)
- action: labelmap
regex: __tmp_pod_label_(.+)
关键配置说明:
- 启用了持久化存储(20Gi)
- 配置了 Linkerd 特有的抓取规则
- 设置了合理的抓取间隔
- 确保服务端口与容器端口一致(9090)
2. 配置 Linkerd Viz 使用外部 Prometheus
修改 linkerd-viz 的 Helm 配置:
prometheus:
enabled: false
prometheusUrl: "http://prometheus-server.linkerd-viz.svc.cluster.local:9090"
3. 安全策略配置
为确保安全访问,需要配置适当的 Server 和 AuthorizationPolicy:
apiVersion: policy.linkerd.io/v1beta3
kind: Server
metadata:
name: prometheus-server-admin
namespace: linkerd-viz
spec:
accessPolicy: deny
podSelector:
matchLabels:
app.kubernetes.io/component: server
app.kubernetes.io/instance: prometheus
app.kubernetes.io/name: prometheus
port: 9090
proxyProtocol: HTTP/1
apiVersion: policy.linkerd.io/v1alpha1
kind: AuthorizationPolicy
metadata:
name: prometheus-server-admin
namespace: linkerd-viz
spec:
requiredAuthenticationRefs:
- kind: ServiceAccount
name: metrics-api
namespace: linkerd-viz
targetRef:
group: policy.linkerd.io
kind: Server
name: prometheus-server-admin
4. 扩展 MeshTLSAuthentication
更新 allow-viz 策略以包含 Prometheus 相关身份:
apiVersion: policy.linkerd.io/v1alpha1
kind: MeshTLSAuthentication
metadata:
name: linkerd-viz
namespace: linkerd-viz
spec:
identities:
- "tap.linkerd-viz.serviceaccount.identity.linkerd.cluster.local"
- "prometheus.linkerd-viz.serviceaccount.identity.linkerd.cluster.local"
- "prometheus-server.linkerd-viz.serviceaccount.identity.linkerd.cluster.local"
验证与调试
完成配置后,需要进行以下验证:
- 检查 Prometheus 目标状态是否健康
- 确认 linkerd viz dashboard 显示正常
- 测试 linkerd viz routes 命令功能
- 检查各组件日志是否有错误
常见问题排查点:
- Prometheus 配置必须放在 serverFiles 下而非 server
- 确保服务端口配置正确
- 检查网络策略是否允许必要通信
- 验证身份认证配置是否正确
最佳实践建议
- 根据集群规模调整 Prometheus 的存储大小
- 考虑设置适当的保留策略
- 定期备份 Prometheus 数据
- 监控 Prometheus 资源使用情况
- 考虑使用 Thanos 或 Cortex 实现长期存储
通过以上配置,Linkerd2 的监控数据将持久化存储在外部 Prometheus 中,既保留了 Linkerd 提供的丰富监控功能,又解决了数据持久化问题,为服务网格的长期运行监控提供了可靠保障。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0190
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0113
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08
项目优选
收起
deepin linux kernel
C
32
16
暂无描述
Dockerfile
762
4.95 K
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.8 K
190
Fflutter_flutter
暂无简介
Dart
1 K
260
Ascend Extension for PyTorch
Python
717
869
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
854
1.91 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.07 K
1.09 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.73 K
1.02 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
676
1.32 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
455
438