微服务常用日志追踪方案:Sleuth + Zipkin + ELK

在微服务架构中,一个用户请求往往需要经过多个服务的协同处理。为了有效追踪请求的完整调用链路,需要一套完整的日志追踪方案。Sleuth + Zipkin + ELK 组合提供了完整的解决方案

  • Sleuth:生成和传播追踪ID
  • Zipkin:收集、存储和可视化追踪数据
  • ELK:集中存储和检索业务日志
  • MDC:实现日志与追踪上下文的关联

1.组件介绍

组件一:Spring Cloud Sleuth

自动生成唯一的TraceID和SpanID,通过HTTP头或消息中间件在服务间传播这些ID,与MDC集成,将追踪信息注入日志

yaml 复制代码
spring:
  sleuth:
    sampler:
      probability: 1.0 # 采样率,1.0表示100%采样
    propagation:
      type: B3 # 使用Zipkin的B3传播协议

组件二:Zipkin

收集各服务上报的追踪数据,存储调用链路信息,提供可视化界面展示调用链路和耗时

服务 → 上报数据 → Zipkin Collector → Storage → Zipkin UI

存储选项:开发环境使用内存,正式环境推荐配置为Elasticsearch

yaml 复制代码
spring:
  zipkin:
    base-url: http://zipkin-server:9411
    sender:
      type: web # 使用HTTP方式上报

组件三:ELK Stack (Elasticsearch + Logstash + Kibana)

Elasticsearch用于存储和索引日志数据 ,Logstash用于收集、过滤和转发日志,Kibana用于可视化查询和分析日志。确保日志中包含TraceID,便于通过TraceID关联业务日志和调用链路

2.完整请求链路示例

  • 用户请求到达服务A,生成TraceID: abc123,生成SpanID: def456

  • 服务A调用服务B,携带HTTP头: X-B3-TraceId=abc123, X-B3-ParentSpanId=def456,服务B生成新SpanID: ghi789

  • 日志输出

matlab 复制代码
服务A日志: [abc123,def456,order-111] INFO ... 创建订单开始
服务B日志: [abc123,ghi789,order-111] INFO ... 库存扣减开始
  • 调用链路信息上报Zipkin,业务日志发送到ELK
  • 通过Zipkin发现异常服务,通过TraceID在ELK中查找相关日志,通过业务ID追踪特定业务对象全链路
相关推荐
赋创小助手8 分钟前
一文了解 GPU 服务器及其在数据中心中的角色
运维·服务器·人工智能·科技·架构
链上Sniper2 小时前
智能合约安全漏洞解析:从 Reentrancy 到 Integer Overflow
开发语言·网络·架构·区块链·php·智能合约
SimonKing3 小时前
揭秘自定义注解,背后的面向切面编程(AOP)的艺术
java·后端·架构
前端Junker3 小时前
《前端设计模式魔法手册》-观察者模式(Observer Pattern)——前端组件通信的「广播电台」
前端·架构
DemonAvenger3 小时前
Go内存对齐:提升访问效率的关键
性能优化·架构·go
掘金-我是哪吒3 小时前
分布式微服务系统架构第143集:pom文件
分布式·微服务·云原生·架构
小艺E3 小时前
联通专线赋能,亿林网络裸金属服务器:中小企业 IT 架构升级优选方案
服务器·网络·架构
Wang's Blog4 小时前
Monorepo架构: 项目管理模式对比与考量
架构·monorepo
链上Sniper4 小时前
高并发区块链系统实战:从架构设计到性能优化
开发语言·网络·python·性能优化·架构·区块链·php
链上Sniper5 小时前
NFT 市场开发:基于 Ethereum 和 IPFS 构建去中心化平台
开发语言·网络·架构·去中心化·区块链·php