日志流水号现有问题
在本篇文档内 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