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'
무엇이 여기에 있습니까?
catalina.out에 관련 예외 또는 오류가 있습니까? –
@AlexeyR., 아니요. 처음에는 log4j 구성 파일을 찾을 수 없다는 내용이있었습니다. 리소스 폴더로 옮겼습니다. 오류 메시지가 사라졌습니다. –
ok. log4j-jcl을 build.gradle에 대한 종속성으로 추가하는 것이 트릭을 만들었습니다. 정확히 무엇이 고정되어 있는지, 여기서 대답을 게시하는지 알아낼 것입니다. –