Where should I put logging.properties file for jav

2019-03-26 15:15发布

问题:

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.

回答1:

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 in WEB-INF/classes If you are using maven to organize the web app, you must know that everything that lies in src/main/resources goes to WEB-INF/classes.



回答2:

you should put in src/main/resources



回答3:

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 add org.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:

<plugins>
  <plugin>
    <artifactId>maven-surefire-plugin</artifactId>
    <configuration>
       <systemProperties>
         <property> 
           <name>java.util.logging.config.file</name>
           <value>src/test/resources/logging.properties</value>
         </property>
         <property>
           <name>java.util.logging.manager</name>
           <value>org.apache.juli.ClassLoaderLogManager</value>
         </property>
       </systemProperties>
    </configuration>
  </plugin>
</plugins>

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 used src/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.



回答4:

If you are using Tomcat, then you should log to $CATALINA_HOME/logs/myapp/myapp.log.