2017-09-15 20 views
0

log4j2 구성 파일에서 사용할 수있는 디버그 로그를 볼 수 없습니다.웹 응용 프로그램에서 log4j2 구성

내 코드 구성은 다음과 같습니다. 난 gradle '자바'와 '전쟁'플러그인을 사용하고 내 코드 조직은 거기에 지정된 기본값에 따라입니다.

. 
├── 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> 

내가 언급 here

로 서블릿 스펙 3.1을 사용할 때 내 web.xml을 명시 적으로 log4j2 구성하지 않습니다이 내 배포 구조

. 
├── 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 종속성을 my로 가져 오는 방법입니다. 프로젝트

// 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

스프링은 로깅을 위해 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' 

내 질문 로깅 아무도 내 응용 프로그램 로그를 포함하여 표시되지 않았 음을 시사하는 것 같다. 나는 거기에서 틀렸다. 샘플 애플리케이션에 아직 로그가 없으므로 스프링 디버그 로그가 아닌 것으로 착각했습니다.