Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/logging/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 使用log4j2配置文件设置记录器时_Java_Logging_Log4j2 - Fatal编程技术网

Java 使用log4j2配置文件设置记录器时

Java 使用log4j2配置文件设置记录器时,java,logging,log4j2,Java,Logging,Log4j2,我已经创建了一个log4j2.xml文件。何时用于启动和配置记录器?JVM启动时?Log4J1 从Log4J1的角度来看,有两种情况下启动了配置: 您可以通过编程方式初始化所有调用BasicConfigurator.configure()的配置 自动配置将查看类路径以查找配置文件。这是文档的摘录: log4j库不会对其环境进行任何假设。 特别是,没有默认的log4j附加器。在一定条件下 但是,在定义明确的情况下,记录器的静态初始化器 类将尝试自动配置log4j。Java语言 保证类的静态初始值设

我已经创建了一个log4j2.xml文件。何时用于启动和配置记录器?JVM启动时?

Log4J1 从Log4J1的角度来看,有两种情况下启动了配置:

  • 您可以通过编程方式初始化所有调用
    BasicConfigurator.configure()的配置
  • 自动配置将查看类路径以查找配置文件。这是文档的摘录:
  • log4j库不会对其环境进行任何假设。 特别是,没有默认的log4j附加器。在一定条件下 但是,在定义明确的情况下,记录器的静态初始化器 类将尝试自动配置log4j。Java语言 保证类的静态初始值设定项被调用一次并且 在将类加载到内存中的过程中仅执行一次。这很重要 要记住,不同的类加载器可能会加载 同一个班级。同一类别的这些副本被视为 JVM完全不相关

    Log4J2 在log4J2中,他们已经改变了程序化的方式,您可以找到很多方法。自动方式没有改变,因此,在JVM加载静态块时加载它。您可以看到它在配置文件中的外观。从log4j2的

    Log4j能够在运行期间自动配置自身 初始化。当Log4j启动时,它将定位所有 ConfigurationFactory插件,并从 从最高到最低。交付时,Log4j包含四个 ConfigurationFactory实现:一个用于JSON,一个用于YAML,一个用于 一个用于属性,一个用于XML


    我的问题是关于log4j2的。您的答案是针对log4j1的。我正在查找log4j2的文档,但我相信在中不存在相同的@Andy897BasicConfiguratorlog4j2@Andy897,我编辑了答案以包含有关log4j2的信息。