SpringCloud Gateway日志唯一流水号优化

日志流水号现有问题
在本篇文档内 https://blog.csdn.net/sweatOtt/article/details/121617075 实现了对请求、响应报文的打印,实现流水号关联请求和响应报文。如下图中,请求和响应的日志流水号相同。
SpringCloud Gateway日志唯一流水号优化_第1张图片

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

SpringCloud Gateway日志唯一流水号优化_第2张图片

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

SpringCloud Gateway日志唯一流水号优化_第3张图片

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

SpringCloud Gateway日志唯一流水号优化_第4张图片

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

SpringCloud Gateway日志唯一流水号优化_第5张图片

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

SpringCloud Gateway日志唯一流水号优化_第6张图片

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

你可能感兴趣的:(spring,cloud,gateway,java)