当前位置:首页 > 技术 > 正文内容

Spring Cloud Sleuth实现分布式服务追踪

访客 技术 2026年6月21日 9

使用Spring Cloud Sleuth为微服务系统添加分布式追踪能力,通过唯一标识符关联跨服务调用日志。

环境准备

1. 服务注册中心
部署Eureka Server作为服务发现组件。

2. 创建服务调用方service-a
实现REST端点/invoke,通过Ribbon调用下游服务:

// 应用配置
spring.application.name=service-a
server.port=9001
eureka.client.service-url.default-zone=http://localhost:1001/eureka/
@RestController
public class ServiceAController {
    @Autowired
    private RestTemplate client;

    @GetMapping("/invoke")
    public String execute() {
        return client.getForEntity("http://service-b/response", String.class).getBody();
    }
}

@Configuration
class AppConfig {
    @Bean
    @LoadBalanced
    RestTemplate restTemplate() {
        return new RestTemplate();
    }
}

3. 创建服务提供方service-b
提供/response端点供service-a调用:

// 应用配置
spring.application.name=service-b
server.port=9002
eureka.client.service-url.default-zone=http://localhost:1001/eureka/
@RestController
public class ServiceBController {
    @GetMapping("/response")
    public String process() {
        return "ServiceResponse";
    }
}

4. 验证基础调用
启动Eureka、service-a和service-b后,请求http://localhost:9001/invoke返回"ServiceResponse"。日志显示独立服务记录:

// service-a日志
INFO ServiceAController: ServiceA request initiated

// service-b日志
INFO ServiceBController: Processing request

集成追踪功能

5. 添加Sleuth依赖
在service-a和service-b的pom.xml中添加:

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-sleuth</artifactId>
</dependency>

6. 观察追踪日志
重启服务后请求相同接口,日志新增追踪标识:

// service-a日志
INFO [service-a,8da1b3f472c584a2,8da1b3f472c584a2,true] ServiceAController: ServiceA request initiated

// service-b日志
INFO [service-b,8da1b3f472c584a2,6c4f8921e539b0d1,true] ServiceBController: Processing request

追踪标识解析

  • 应用名称spring.application.name配置值
  • Trace ID:请求链路唯一标识(示例中8da1b3f472c584a2
  • Span ID:单个工作单元标识(service-a中8da1b3f472c584a2,service-b中6c4f8921e539b0d1
  • 采样标志:控制日志是否输出到收集器

7. 通信过程增强
Sleuth自动在HTTP头注入追踪参数:

  • X-B3-TraceId:链路追踪ID
  • X-B3-SpanId:当前操作单元ID
  • X-B3-ParentSpanId:父单元ID(首节点为空)

8. 自定义追踪日志
在service-b中获取并记录HTTP头信息:

@RestController
public class ServiceBController {
    @GetMapping("/response")
    public String process(HttpServletRequest req) {
        logger.info("TraceID={}, SpanID={}", 
                    req.getHeader("X-B3-TraceId"),
                    req.getHeader("X-B3-SpanId"));
        return "ServiceResponse";
    }
}

9. 启用详细日志
在application.properties添加:

logging.level.org.springframework.web.servlet.DispatcherServlet=DEBUG

DEBUG日志将显示请求处理全过程与追踪ID关联。

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。