首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Java项目中的Log4j2配置文件

Java项目中的Log4j2配置文件
EN

Stack Overflow用户
提问于 2019-02-23 20:13:17
回答 2查看 438关注 0票数 1

我在运行在Windows10中的Maven中有基于Jersey web服务的简单Eclipse Java。项目是由jersey-quickstart-webapp工件创建的。我正在尝试使用Log4j记录器,但无法找到放置log4j2.xml文件的位置。我试图将它与源代码java文件放在一起,但是logger抱怨没有找到配置文件。保存配置文件的正确位置是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-02-23 20:56:19

把它放到资源目录中。通常,所有配置文件都保存在那里。

票数 0
EN

Stack Overflow用户

发布于 2019-02-23 20:25:31

根据文档,Log4j2将按照以下顺序查找配置文件:

  1. Log4j将检查"log4j.configurationFile“系统属性,如果设置,将尝试使用与文件扩展名匹配的ConfigurationFactory加载配置。
  2. 如果没有设置任何系统属性,ConfigurationFactory将在类路径中查找log4j2-test.properties。
  3. 如果没有找到这样的文件,YAML ConfigurationFactory将在类路径中查找log4j2-test.yaml或log4j2-test.yml。
  4. 如果没有找到这样的文件,JSON ConfigurationFactory将在类路径中查找log4j2-test.json或log4j2-test.jsn。
  5. 如果没有找到这样的文件,XML ConfigurationFactory将在类路径中查找log4j2-test.xml。
  6. 如果无法找到测试文件,ConfigurationFactory将在类路径上查找log4j2属性。
  7. 如果不能找到属性文件,YAML ConfigurationFactory将在类路径上查找log4j2.yaml或log4j2.yml。
  8. 如果无法找到YAML文件,JSON ConfigurationFactory将在类路径上查找log4j2.json或log4j2.jsn。
  9. 如果无法找到JSON文件,XML将尝试在类路径上定位log4j2.xml。
  10. 如果无法找到配置文件,则将使用DefaultConfiguration。这将导致日志输出转到控制台。

因此,您可以看到,除了(1)之外,所有人都在从类路径中查看配置文件。在标准Maven项目中,/src/main/resources是您可以将log4j2.xml放在/src/main/resources中的类路径.So的根。

否则,必须通过log4j.configurationFile system属性显式指定配置文件:

代码语言:javascript
复制
-Dlog4j.configurationFile=path/to/log4j2.xml
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54845754

复制
相关文章

相似问题

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