skywalking springgateway 全链路

本文介绍了如何在SpringCloudGateway3.1.0版本中整合SkyWalking,包括添加特定插件、配置请求标识以及将SkyWalkingTraceId放入响应头。作者提供了详细步骤和所需依赖,确保全链路追踪功能的实现。
摘要由CSDN通过智能技术生成

环境

spring-cloud-gateway 3.1.0

springGateway整合skywalking

skywalking 默认是不整合springGateway的,需要手动拷贝skywalking optional-plugins下的
apm-spring-cloud-gateway-N.x-plugin-8.13.0.jar

apm-spring-webflux-5.x-plugin-8.13.0.jar
架包拷贝到plugins目录下
gateway架包的选择根据springgateway的版本进行选择
在这里插入图片描述

配置请求标识

经过上一步配置的请求会存在调用链路,但是链路仅到网关,不会到后续服务

处理方法

  1. 服务中引入架包
    pom
        <dependency>
            <groupId>org.apache.skywalking</groupId>
            <artifactId>apm-toolkit-trace</artifactId>
            <version>8.14.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.skywalking</groupId>
            <artifactId>apm-toolkit-webflux</artifactId>
            <version>8.14.0</version>
        </dependency>
  1. 配置链路id
package com.kittlen.gateway.filter;

import org.apache.skywalking.apm.toolkit.trace.TraceContext;
import org.apache.skywalking.apm.toolkit.webflux.WebFluxSkyWalkingOperators;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;

/**
 * @author kittlen
 * @version 1.0
 * @date 2023/9/5 13:41
 * skywalking 全链路配置
 */
@Component
public class PutTraceIdIntoResponseHeaderFilter implements GlobalFilter {

    String xTraceIdKey = "x-trace-id";

    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        String traceId = WebFluxSkyWalkingOperators.continueTracing(exchange, TraceContext::traceId);
        exchange.getResponse().getHeaders().set(xTraceIdKey, traceId);
        return chain.filter(exchange);
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值