首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Log4j的ThreadContext自动清除

Log4j的ThreadContext自动清除
EN

Stack Overflow用户
提问于 2022-03-16 12:53:05
回答 1查看 408关注 0票数 0

我在应用程序开始时将一个键插入到ThreadContext映射中,如下所示,

代码语言:javascript
复制
protected void doFilterWrapped(ContentCachingRequestWrapper request,
      ContentCachingResponseWrapper response, FilterChain filterChain)
      throws ServletException, IOException {
    // some code...
    ThreadContext.put(Constants.REQUEST_ID, requestID);
    ThreadContext.put(requestID + Constants.HASH + "retryCount", "-1");
    // some more code...
  }

现在,在其他类中,我试图像这样更新键requestID + Constants.HASH + "retryCount"的值,

代码语言:javascript
复制
String key = ThreadContext.get(Constants.REQUEST_ID) + Constants.HASH + "retryCount";
      if (ThreadContext.containsKey(key)) {
        ThreadContext.put(key, String.valueOf(Integer.valueOf(ThreadContext.get(key)) + 1));
      } else {
        ThreadContext.put(key, "-1");
      }
      System.out.println("\n\n  " + ThreadContext.get(key) + " \n\n");

但是它只工作了一次,之后它无法找到key,即ThreadContext.containsKey(key)false

有人能解释一下是什么问题吗。

EN

回答 1

Stack Overflow用户

发布于 2022-08-01 16:38:53

是否尝试过设置“标题上下文可继承系统”属性?在应用程序启动时,添加以下一行:

代码语言:javascript
复制
System.setProperty("isThreadContextMapInheritable", "true");

启用此属性后,子线程将继承线程上下文。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71497444

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档