2017-09-15 138 views
0

我无法看到我在log4j2配置文件中启用的调试日志。在web应用程序中配置log4j2

我的代码组织如下。我使用gradle'java'和'war'插件,我的代码组织是根据在那里指定的默认值。

. 
├── main 
│   ├── java 
│   │   └── am 
│   │    └── login 
│   │     ├── common 
│   │     │   └── LoginWebAppConfiguration.java 
│   │     └── google 
│   │      └── GoogleLogin.java 
│   ├── resources 
│   │   └── log4j2.xml 
│   └── webapp 
│    └── WEB-INF 
│     ├── pages 
│     │   └── google.html 
│     ├── spring 
│     │   └── mvc 
│     │    └── login-servlet.xml 
│     └── web.xml 
└── test 
    ├── java 
    └── resources 

我log4j2配置

<?xml version="1.0" encoding="UTF-8"?> 

<Configuration status="WARN" monitorInterval="5"> 
    <Appenders> 
     <Console name="Console" target="SYSTEM_OUT"> 
      <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" /> 
     </Console> 
      <File name="LogFile" fileName="logs/login.log"> 
       <PatternLayout> 
        <Pattern>%d %p %c{1.} [%t] %m%n</Pattern> 
       </PatternLayout> 
      </File> 
    </Appenders> 

    <Loggers> 
     <Root level="DEBUG"> 
      <AppenderRef ref="Console" /> 
      <AppenderRef ref="LogFile"/> 
     </Root> 
     <Logger name="org.springframework" level="DEBUG" /> 
     <Logger name="am.login" level="DEBUG" /> 
    </Loggers> 
</Configuration> 

我的web.xml中没有明确配置log4j2因为我用Servlet规范3.1的规定here

这是我的部署结构

. 
├── META-INF 
│   ├── MANIFEST.MF 
│   └── war-tracker 
└── WEB-INF 
    ├── classes 
    │   ├── am 
    │   │   └── login 
    │   │    ├── common 
    │   │    │   └── LoginWebAppConfiguration.class 
    │   │    └── google 
    │   │     └── Login.class 
    │   └── log4j2.xml 
    ├── lib 
    │   ├── commons-logging-1.2.jar 
    │   ├── log4j-api-2.9.0.jar 
    │   ├── log4j-core-2.9.0.jar 
    │   ├── log4j-slf4j-impl-2.9.0.jar 
    │   ├── log4j-web-2.9.0.jar 
    │   ├── slf4j-api-1.7.25.jar 
    │   ├── spring-aop-4.3.11.RELEASE.jar 
    │   ├── spring-beans-4.3.11.RELEASE.jar 
    │   ├── spring-context-4.3.11.RELEASE.jar 
    │   ├── spring-core-4.3.11.RELEASE.jar 
    │   ├── spring-expression-4.3.11.RELEASE.jar 
    │   ├── spring-web-4.3.11.RELEASE.jar 
    │   └── spring-webmvc-4.3.11.RELEASE.jar 
    ├── pages 
    │   └── google.html 
    ├── spring 
    │   └── mvc 
    │    └── login-servlet.xml 
    └── web.xml 

这就是我如何将log4j2依赖项导入到我的项目

// log using slf4j 
    compile group: 'org.slf4j', name: 'slf4j-api', version: '1.7.25' 

    // reroute slf4j to log4j2 
    compile group: 'org.apache.logging.log4j', name: 'log4j-slf4j-impl', version: '2.9.0' 
    compile group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.9.0' 
    compile group: 'org.apache.logging.log4j', name: 'log4j-core', version: '2.9.0' 

    // In order to properly support and handle the ClassLoader environment and container lifecycle of a JEE web application 
    compile group: 'org.apache.logging.log4j', name: 'log4j-web', version: '2.9.0' 

我在这里错过了什么?

+0

catalina.out中是否有任何相关的异常或错误? –

+0

@AlexeyR,不,我有一个最初说明的东西,即log4j配置文件找不到。我将它移入资源文件夹中,并且错误消息消失 –

+0

ok。添加log4j-jcl作为依赖到我的build.gradle做了诀窍。我会弄清楚它究竟修复了什么,并在此发布答案 –

回答

0

Spring使用JCL进行日志记录。我需要在我的类路径中包含JCL API的log4j2实现,以便弹出日志。请参阅this

我的build.gradle现在看起来像这样用于记录依赖

// log using slf4j 
    compile group: 'org.slf4j', name: 'slf4j-api', version: '1.7.25' 

    // log4j2 binding or implementation for slf4j 
    compile group: 'org.apache.logging.log4j', name: 'log4j-slf4j-impl', version: '2.9.0' 

    // spring uses apache commons logging api. This provides a log4j2 implementation for commons logging 
    compile 'org.apache.logging.log4j:log4j-jcl:2.9.0' 

我的问题似乎表明,没有任何记录的是出现包括我的应用程序日志。那里我错了。我的示例应用程序还没有任何日志,我错误地认为没有弹出调试日志。