首页 > 解决方案 > 为什么静态值与 appender(log4j 自定义 appender)不同?

问题描述

我在春天做这样的静态变量。

public class A {
  private static final Map<String, Session> listMap = new HashMap<>();
  public static Map<String> getMap() { return this.listMap.values() }
  public static void addMap(String name, Session s) { return this.listMap.put(name, s) }
}

我保存在服务层。

@Slf4j
public class BService {
  public void addSession(String name, Session s) { 
    A.addMap("a", s);
    log.info("added!");
  }
}

保存后,我在自定义 appender 中使用它。(https://www.baeldung.com/log4j2-custom-appender

@Plugin(
  name = "MapAppender", 
  category = Core.CATEGORY_NAME, 
  elementType = Appender.ELEMENT_TYPE)
public class MapAppender extends AbstractAppender {

    private ConcurrentMap<String, LogEvent> eventMap = new ConcurrentHashMap<>();

    protected MapAppender(String name, Filter filter) {
        super(name, filter, null);
    }

    @PluginFactory
    public static MapAppender createAppender(
      @PluginAttribute("name") String name, 
      @PluginElement("Filter") Filter filter) {
        return new MapAppender(name, filter);
    }

    @Override
    public void append(LogEvent event) {
        Map<> resultMap = A.getMap();
        send()
    }
}

然而,当 appender 的 append() 方法被执行时,A.getMap()什么也不返回(size 0)。(A.getMap() 在服务层正确返回。)为什么静态值不同?..

标签: javaspring-bootstaticlog4jappender

解决方案


listMap调用时加载,addSession所以它是空的 当append()方法被调用时


推荐阅读