SpringCloud Gateway日志唯一流水号优化

日志流水号现有问题
在本篇文档内 https://blog.csdn.net/sweatOtt/article/details/121617075 实现了对请求、响应报文的打印,实现流水号关联请求和响应报文。如下图中,请求和响应的日志流水号相同。
在这里插入图片描述

由于Gateway收到、处理请求和发送后端应用,使用的线程不同。接受、处理请求为SpringCloud Gateway WebFlux线程,发送后端应用使用的微netty client线程。导致SpringCloud Gateway Filter内设置的流水号,无法在Netty client中获取。最终同一笔请求的日志,Gateway filter内的流水号和Netty内的流水号不同。

在这里插入图片描述

例如下图为同一笔请求,其中hystrix降级、ribbon日志和请求、响应日志的流水号不同。当网关TPS高时,日志并非是有序的,无法关联hystrix降级和请求、响应报文日志。

在这里插入图片描述

全局唯一流水号优化
为了实现Netty线程和Gateway线程内,能够获取到相同的流水号,我们需要在调用Netty时,将Gateway的流水号传递给Netty线程,实现统一的流水号。
重写SpringCloud Gateway NettyRoutingFilter类。

在这里插入图片描述

修改内容如下,将Gateway线程内的流水号,传递给Netty线程。

在这里插入图片描述

通过此方式,Gateway线程的流水号和Netty线程的流水号完全一致,实现一笔请求全局唯一的日志流水号。

在这里插入图片描述

可以参考整理的代码工程实现统一的流水号。Github 连接 https://github.com/sweat123/SpringCloudGatewayLogFlowId

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值