SpringBoot 单体服务集成 Zipkin 实现链路追踪

在现代微服务或单体应用中,了解请求的执行路径和耗时非常重要。本文介绍如何在 Spring Boot 单体服务中快速集成 Zipkin,实现链路追踪和可视化分析。

一、准备工作

1. 下载 Zipkin Server

复制代码
wget https://repo1.maven.org/maven2/io/zipkin/java/zipkin-server/2.24.3/zipkin-server-2.24.3-exec.jar

2. 启动 Zipkin Server

复制代码
java -jar zipkin-server-2.24.3-exec.jar --server.port=9411

后台启动

复制代码
nohup java -jar zipkin-server-2.24.3-exec.jar --server.port=9411 &

访问 http://localhost:9411/zipkin 可以看到 Zipkin 首页。

二、Spring Boot 项目依赖

pom.xml 中添加 Sleuth 和 Zipkin 依赖:

复制代码
<!-- Zipkin: 生成和收集追踪数据 -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-sleuth</artifactId>
    <version>3.1.8</version> <!-- 与 Spring Boot 2.7.x 兼容 -->
</dependency>

<!-- Zipkin: 将追踪数据发送到 Zipkin Server -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-sleuth-zipkin</artifactId>
    <version>3.1.8</version>
</dependency>

三、配置 Zipkin 和 Sleuth

application.yml 中添加链路追踪配置:

复制代码
spring:
  application:
    name: yudao-server
  profiles:
    active: local

  # Zipkin 链路追踪配置
  zipkin:
    base-url: http://localhost:9411
    sender:
      type: web
  sleuth:
    sampler:
      probability: 1.0  # 采样率:1.0=100%,生产环境可调整为0.1

这样,每个请求都会生成一个 Trace ID 并发送到 Zipkin。

四、启动 Spring Boot 服务

复制代码
java -jar yudao-server.jar

五、查看链路追踪数据

  1. 打开 Zipkin 页面 http://localhost:9411/zipkin

  2. 在首页点击 "找到一个痕迹"

  3. 搜索条件填写:

  • Service Name : yudao-server

  • 时间范围: 最近 1 小时或自定义

  1. 点击 查找,即可查看请求的执行链路。

六、追踪详情解析

每个 Trace 记录包含:

  • 时间线视图:显示每个 Span 的执行时间和顺序

  • 层级结构:展示父子调用关系

  • 关键字段

    • Trace ID:整个请求链路唯一标识

    • Span ID:每个操作唯一标识

    • 标签信息:HTTP 方法、路径、状态码等

七、查看服务依赖

点击顶部菜单 "依赖",可看到服务调用关系图,包括:

  • yudao-server 与数据库、Redis 等服务依赖

  • 调用频率与错误率

八、生成测试流量

为了让 Zipkin 捕获数据,可以调用服务接口:

复制代码
curl http://localhost:48080/admin-api/system/auth/sms-login

刷新 Zipkin 页面,即可看到新的追踪记录。

九、总结

通过以上步骤,Spring Boot 单体服务就能快速接入 Zipkin 链路追踪:

  • 快速定位慢请求和性能瓶颈

  • 可视化调用关系

  • 支持分布式和单体应用

对于生产环境,可以调整采样率和 Zipkin 存储方式(如 MySQL、Elasticsearch),以满足性能和存储需求。

相关推荐
小码哥_常3 小时前
Spring Boot 牵手Spring AI,玩转DeepSeek大模型
后端
0xDevNull3 小时前
Java反射机制深度解析:从原理到实战
java·开发语言·后端
华洛3 小时前
我用AI做了一个48秒的真人精品漫剧,不难也不贵
前端·javascript·后端
华科易迅3 小时前
MybatisPlus增删改查操作
android·java·数据库
WZTTMoon3 小时前
Spring Boot 中Servlet、Filter、Listener 四种注册方式全解析
spring boot·后端·servlet
standovon4 小时前
Spring Boot整合Redisson的两种方式
java·spring boot·后端
Cosolar4 小时前
LlamaIndex RAG 本地部署+API服务,快速搭建一个知识库检索助手
后端·openai·ai编程
IAUTOMOBILE4 小时前
Python 流程控制与函数定义:从调试现场到工程实践
java·前端·python
hutengyi4 小时前
PostgreSQL版本选择
java
皮皮林5514 小时前
重磅!JetBrains 正式发布全新的 AI 开发工具,定名 AI IDE AIR
java·intellij idea