如何在调用 LogManager.shutdown() 后重新启动 log4j2?

Wei*_*eff 4 log4j2

我有一个重新配置 log4j2 的方法,如下所示:

LogManager.shutdown(); // SHUTDOWN log4j2
    InputStream in = getClass().getResourceAsStream("/my2ndLog4j2.xml");
    ConfigurationSource source = new ConfigurationSource(in);
    Configurator.initialize(null, source);
    LoggerContext context = (LoggerContext) LogManager.getContext(false);
    context.reconfigure();
    context.start(); // NOT WORK, no log appear anymore...
Run Code Online (Sandbox Code Playgroud)

所以我可以在运行时在生产日志配置和开发配置之间重新配置log4j2,但是当我调用LogManager.shutdown()时,它真的永远关闭,永远不会回来,context.start()不起作用,事实上我在log4j1中这样做。 x很长一段时间,在log4j1.x中,使用:

org.apache.log4j.PropertyConfigurator.configure(cfgPath);
Run Code Online (Sandbox Code Playgroud)

然后它就回来了,但是log4j2怎么办?

Vik*_*eva 5

如果您想log4j2在运行时更改配置文件,那么下面的代码足以做到这一点 -

Configurator.initialize(null, "my2ndLog4j2.properties");
Run Code Online (Sandbox Code Playgroud)

无需关闭LogManager然后重新启动。