Gateway 请求链路

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Cloud Gateway 中,可以使用 SkyWalking 提供的插件来实现链路追踪。具体步骤如下: 1. 添加 SkyWalking 插件的依赖: ```xml <dependency> <groupId>org.apache.skywalking</groupId> <artifactId>apm-toolkit-trace</artifactId> <version>${skywalking.version}</version> </dependency> <dependency> <groupId>org.apache.skywalking</groupId> <artifactId>apm-toolkit-opentracing</artifactId> <version>${skywalking.version}</version> </dependency> <dependency> <groupId>org.apache.skywalking</groupId> <artifactId>apm-toolkit-log4j-1.x</artifactId> <version>${skywalking.version}</version> </dependency> ``` 其中 `${skywalking.version}` 是 SkyWalking 版本号。 2. 创建一个 `GlobalFilter`,在该过滤器中添加 SkyWalking 的 `TracingContext`: ```java @Component public class SkyWalkingFilter implements GlobalFilter, Ordered { @Override public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { Tracer tracer = TracingContext.Tracing().tracer(); Span span = tracer.createEntrySpan(exchange.getRequest().getURI().getPath()); try { // 在这里处理逻辑 return chain.filter(exchange); } finally { span.asyncFinish(); } } @Override public int getOrder() { return Ordered.LOWEST_PRECEDENCE; } } ``` 在过滤器中使用 `TracingContext.Tracing().tracer()` 获取当前线程的 `Tracer`,并使用 `tracer.createEntrySpan()` 创建一个入口 Span。在请求处理完成后,需要在 `finally` 块中调用 `span.asyncFinish()` 来结束该 Span。 3. 在 `application.yml` 中配置 SkyWalking: ```yaml skywalking: trace: ignore-path: /actuator/** ignored-tracers: org.springframework.cloud.gateway.filter.factory.rewrite.CachedBodyOutputMessage ``` 其中 `ignore-path` 表示不进行链路追踪的路径,`ignored-tracers` 表示需要忽略的 Tracer。 4. 启动 SkyWalking Agent,就可以在 SkyWalking 的控制台中看到链路追踪信息了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值