当使用http调用X-Request-Id时,我希望将从Nginx接收到的k8s传播到k8s中的其他服务。
现在,我正在使用请求筛选器来捕获X-Request-Id头并将其放入MDC。
final String nginxRequestId = requestContext.getHeaderString("X-Request-Id");
if (nginxRequestId != null) {
MDC.put("infra_request", nginxRequestId);
}现在,我在k8s中调用服务B的端点(因此不需要Nginx ),我希望获得该X-Request-Id,以便将其放入请求的头中。我可以在这里看到两种选择:
中。
我可能会使用MDC来完成它,但我不确定这是否是最佳实践,或者是否存在一些捕获/问题。
发布于 2020-06-02 08:11:22
我认为就你的目的而言,使用MDC是件好事。在内部MDC使用ThreadLocal。即使您使用ThreadLocal,为了实现更好的方法,您也会将ThreadLocal变量包装在类中。MDC对你也是这样。
发布于 2020-06-02 09:09:41
我使用MDC和ThreadLocal来实现将一个事务id传递给报头的类似目的。在内部,MDC使用ThreadLocal,它具有一些预定义的功能,比如在每个日志中添加一个前缀。如果您正在放置的数据具有某些业务用途,我建议您使用ThreadLocal,否则,您可以使用MDC。
https://stackoverflow.com/questions/62147134
复制相似问题