Je ne parviens pas à voir les journaux de débogage activés dans le fichier de configuration log4j2.Configuration de log4j2 dans une application Web
Mon organisation de code est comme ci-dessous. J'utilise le plugin 'java' et 'war' gradle et mon organisation de code est en accord avec les valeurs par défaut spécifiées ici.
.
├── 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
Ma configuration 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>
Mon web.xml ne configurez pas explicitement log4j2 que j'utilise la spécification Servlet 3.1 comme indiqué here
Ceci est ma structure de déploiement
.
├── 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
Voici comment j'importe les dépendances log4j2 dans mon projet
// 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'
Que manque-t-il ici?
Existe-t-il des exceptions ou des erreurs pertinentes dans catalina.out? –
@AlexeyR., Non. Au début, j'avais déclaré que le fichier de configuration log4j était introuvable. Je l'ai déplacé dans le dossier des ressources et ce message d'erreur a disparu –
ok. l'ajout de log4j-jcl en tant que dépendance à mon build.gradle a fait l'affaire. Je vais comprendre exactement ce que cela a corrigé et afficher la réponse ici –