I want to logging to file and set it in properties file, because default logger.info() output goes to console and in web application there is no console in my case.
相关问题
- Delete Messages from a Topic in Apache Kafka
- Jackson Deserialization not calling deserialize on
- How to maintain order of key-value in DataFrame sa
- StackExchange API - Deserialize Date in JSON Respo
- Difference between Types.INTEGER and Types.NULL in
you should put in src/main/resources
If you are using Tomcat, then you should log to
$CATALINA_HOME/logs/myapp/myapp.log
.This is the first place I found when I was trying to figure out where my logging.properties file needed to go while testing.
TL;DR:
src/test/resources
Deploy to Tomcat
When running as a web application, as this comment suggests, I don't need to deploy a logging.properties file to
src/main/resources
(although that probably would have fixed my immediate problem). My container already has one. For Tomcat, that location is$CATALINA_HOME/conf/logging.properties
. If you are running Tomcat from Eclipse, you can set that in launch configuration, as explained here.This answer talks about setting up different logging properties per application, which is what putting the file in
src/main/resources
does.This section is the answer to the poster's question. The rest of this is the answer to my similar but different problem.
Debugging tests
The actual problem that I was having was that my
java.util.logging
stopped showing the class name and method name after I added an SLF4J-using jar to my project and was trying to debug my unit tests. I had to addorg.slf4j:slf4j-jdk14
to my POM in Provided scope so that my tests would run at all. But then they didn't have class and method names. Configuring the logging.properties file to match the one for Tomcat but with different handlers fixed that after I added some Surefire configuration:And my logs once again were showing all the information even when running tests from Maven.
Summary
If you want to set how your regular application is logging, then
src/main/resources
may be the right place. But I wanted to change how my tests were logging, so I usedsrc/test/resources
instead. Since Tomcat's launch configuration doesn't run under typical unit tests, I had to add some configuration to Surefire to serve the same purpose. The logging.properties outside Tomcat does not use any Catalina jars, so I switched it to use different handlers.As Navi says... it goes in
src/main/resources
Just to clarify this subject... the logging.properties must go in
WEB-INF/classes
directory. If you are using some kind of framework for organizing your project, you must find out where to place the file in order to stay inWEB-INF/classes
If you are using maven to organize the web app, you must know that everything that lies insrc/main/resources
goes toWEB-INF/classes.