0

0

云原生应用监控与日志收集示例

P粉602998670

P粉602998670

发布时间:2025-10-15 08:39:01

|

657人浏览过

|

来源于php中文网

原创

云原生监控日志方案以Prometheus+Grafana监控指标,EFK收集日志,Jaeger实现分布式追踪,Alertmanager配置告警,构建覆盖指标、日志、追踪的完整可观测体系。

云原生应用监控与日志收集示例

云原生应用的监控与日志收集是保障系统稳定性、可观测性和快速排障的关键环节。随着微服务和容器化架构的普及,传统的监控方式已无法满足动态、分布式的环境需求。以下通过一个典型示例说明如何实现云原生应用的监控与日志收集。

1. 监控体系:Prometheus + Grafana

在云原生环境中,Prometheus 是主流的监控解决方案,擅长采集和存储时间序列数据。

实施步骤:

  • 部署 Prometheus Server,配置其抓取 Kubernetes 集群中各组件(如 kubelet、apiserver)和服务实例的指标。
  • 在应用中集成 Prometheus 客户端库(如 Prometheus Go Client),暴露自定义业务指标(如请求延迟、错误率)。
  • 通过 ServiceMonitor(使用 Prometheus Operator)自动发现并监控目标服务。
  • 部署 Grafana,连接 Prometheus 作为数据源,创建可视化仪表板展示 CPU 使用率、内存、请求量、错误率等关键指标。

例如,一个基于 Go 编写的微服务可通过 /metrics 接口暴露 HTTP 请求计数器,Prometheus 每 15 秒拉取一次数据,Grafana 实时绘图。

2. 日志收集:Fluentd + Elasticsearch + Kibana(EFK)

容器环境中的日志是分散且短暂的,需集中化收集以便分析。

实施方案:

  • 在每个 Kubernetes 节点上部署 Fluentd 作为 DaemonSet,监听容器的日志文件路径(通常挂载 /var/log/containers)。
  • Fluentd 将日志解析为结构化 JSON 格式(如提取 pod_name、namespace、timestamp),并发送至 Elasticsearch。
  • Elasticsearch 存储并索引日志数据,支持高效查询。
  • Kibana 提供 Web 界面,支持按服务、时间、关键字搜索日志,也可设置告警规则。

例如,当某个订单服务报错时,运维人员可在 Kibana 中筛选 namespace=“order-service” 和 level=“error”,快速定位异常堆

FreeTTS
FreeTTS

FreeTTS是一个免费开源的在线文本到语音生成解决方案,可以将文本转换成MP3,

下载

3. 分布式追踪:Jaeger 或 OpenTelemetry

在调用链跨越多个服务时,传统日志难以还原完整流程。

集成方法:

  • 在服务间传递 trace_id 和 span_id(通过 HTTP header)。
  • 使用 OpenTelemetry SDK 自动注入追踪信息,记录每个服务的处理耗时。
  • 将追踪数据导出到 Jaeger 后端
  • 通过 Jaeger UI 查看完整调用链,识别性能瓶颈

比如用户下单失败,可通过 trace_id 查看从网关到库存、支付服务的全流程,确认是哪个环节超时。

4. 告警与通知:Alertmanager 集成

Prometheus 的 Alertmanager 模块可实现灵活告警策略。

配置要点:

  • 在 Prometheus 中定义告警规则,如 “API 错误率连续 5 分钟超过 5%”。
  • Alertmanager 接收告警后,去重、分组,并通过邮件、钉钉或企业微信通知值班人员。
  • 支持静默期和告警恢复通知,避免骚扰。

基本上就这些。一套完整的云原生可观测性体系应覆盖指标、日志和追踪三大支柱,结合自动化工具链,才能实现对复杂系统的有效掌控。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

327

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.10.07

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

417

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

310

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

188

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

288

2023.10.25

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.4万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号