当前位置: 首页 > article >正文

SkyWalking Agent 配置 Spring Cloud Gateway 插件解决日志错误

SkyWalking Agent 配置 Spring Cloud Gateway 插件解决日志错误

IDEA中启动网管时,需要配置VM启动参数,格式如下:

# 配置 SkyWalking Agent 启动参数,以便将网关服务的性能数据上报到 SkyWalking 服务器。
-javaagent:/path/to/skywalking-agent.jar \
-Dskywalking.agent.service_name=${APPLICATION_NAME}-skywalking \
-Dskywalking.collector.backend_service=127.0.0.1:11800
问题详情

在一个应用项目中使用 SkyWalking 监控时,Spring Cloud Gateway 服务上报出如下错误信息:

2024-12-29 16:45:34.076 [TID:N/A] [http-nio-5] ERROR
  o.s.b.a.w.r.error.AbstractErrorWebExceptionHandler:122 - [2349a963-1]  500 Server Error for HTTP GET "/app/consumer/skuInfo/1"
java.lang.NullPointerException: null
    at org.apache.skywalking.apm.plugin.spring.cloud.gateway.v21x.HttpClientFinalizerResponseConnectionInterceptor$1.apply(HttpClientFinalizerResponseConnectionInterceptor.java:42)
...
解决过程

过程分析后发现,错误原因是 SkyWalking Agent 的 plugins 文件夹中缺少对 Spring Cloud Gateway 进行监控的实现插件。此插件位于 SkyWalking Agent 的 optional-plugins 文件夹中,应采取如下步骤进行解决:

  1. 确定 Spring Cloud Gateway 版本

    • 通过命令格式查看项目依赖。
      mvn dependency:tree | grep gateway
      # 或
      gradle dependencies | grep gateway
      
    • 记录项目中 Spring Cloud Gateway 版本,例如「3.x」。
  2. 找到相关插件文件

    • 在 SkyWalking Agent 文件夹中的 optional-plugins 下,找到适配版本的插件:
      apm-spring-cloud-gateway-3.x-plugin-8.9.0.jar
      
  3. 将插件拷贝到 plugins 文件夹

    • 将上述插件文件拷贝到 skywalking-agent/plugins 文件夹中。
  4. 重启服务

    • 重新启动应用项目,检查 SkyWalking 探针是否正常工作。
注意事项
  1. 插件版本对应

    • SkyWalking Agent 的插件需要和项目使用的 Spring Cloud Gateway 版本相匹配。
    • SkyWalking 主版本应与插件版本匹配:
      • 例如,SkyWalking 进行到8.9.0,应使用 apm-spring-cloud-gateway-3.x-plugin-8.9.0.jar
  2. Reactor Netty 依赖关系

    • Spring Cloud Gateway 依赖 Reactor Netty,需要 Reactor Netty 版本和插件声明匹配。
  3. 用 SkyWalking UI 校验效果

    • 启动后,访问相关服务探针,检查是否显示完整的调用链,如响应时间、问题码、路由等。
进阶优化提示
  1. 调试 SkyWalking 日志源

    • 启用 SkyWalking 调试日志,查看插件是否被正确装载。
      logging.level.org.apache.skywalking=DEBUG
      
  2. 优化插件版本

    • 实时升级项目依赖和 SkyWalking 插件,确保与 Spring 最新版本兼容。
  3. 产线通用化添加

    • 在多服务环境中,确保同样插件配置在所有相关服务中完整加载。

http://www.kler.cn/a/458824.html

相关文章:

  • 接口测试Day04-postman生成测试报告ihrm项目
  • 计算机网络面试常见知识框架以及常见面试题解
  • Java 8 及经典面试题全解析
  • 【Rust自学】9.2. Result枚举与可恢复的错误 Pt.1:match、expect和unwrap处理错误
  • 【机器学习 | 数据挖掘】时间序列算法
  • goView二开低代码平台1.0
  • Momentum Contrast for Unsupervised Visual Representation Learning论文笔记
  • Django多字段认证的实现
  • python脚本加载ui页面:PySide6设计的页面
  • SQL 实战:窗口函数进阶 – 实现复杂滑动窗口与动态累计计算
  • 大数据与机器学习(它们有何关系?)
  • Mac电脑python多版本环境安装与切换
  • Selenium之Web元素定位
  • Android笔试面试题AI答之Android基础(7)
  • hive-sql 连续登录五天的用户
  • 【GeekBand】C++设计模式笔记18_State_状态模式
  • 【2024年-6月-21日-开源社区openEuler实践记录】探索 intel-kernel:英特尔架构内核优化之路
  • [TOTP]android kotlin实现 totp身份验证器 类似Google身份验证器
  • 环,域,体,整区,理想,极大理想,
  • 配置hive支持中文注释
  • Lombok是银弹?还是陷阱?
  • golang标准库archive/tar实现打包压缩及解压
  • 《Java核心技术 卷II》流的创建
  • Vue el-data-picker选中开始时间,结束时间自动加半小时
  • 滑动窗口、流量控制和拥塞控制
  • C++笔记-对windows平台上lib和dll的进一步理解(2024-10-21