2017-09-15 113 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' 

我的問題似乎表明,沒有任何記錄的是出現包括我的應用程序日誌。那裏我錯了。我的示例應用程序還沒有任何日誌,我錯誤地認爲沒有彈出調試日誌。