log4j配置,日志路径配置

##设置控制台输出优先级别(如果没有优先级配置控制台将没有输出)、以及输出源
##CONSOLE、STDOUT控制台输出所有级别信息,还可以设置为log4j的5种级别
log4j.rootLogger = ERROR, C, W, E

###输出到控制台
log4j.appender.C = org.apache.log4j.ConsoleAppender
log4j.appender.C.layout = org.apache.log4j.PatternLayout
log4j.appender.C.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [%l]:%m%n

###输出到日志文件
log4j.appender.W = org.apache.log4j.DailyRollingFileAppender
log4j.appender.W.File = ${webApp.root}/logs/log.log
log4j.appender.W.Append = true
##输出WARN级别以上的日志
log4j.appender.W.Threshold = WARN
log4j.appender.W.layout = org.apache.log4j.PatternLayout
log4j.appender.W.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [%l]:%m%n

###保存异常信息到单独文件
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
##异常日志文件名
log4j.appender.E.File = ${webApp.root}/logs/error.log
log4j.appender.E.Append = true
##只输出ERROR级别以上的日志
log4j.appender.E.Threshold = ERROR
##日志格式采用指定布局模式
log4j.appender.E.layout = org.apache.log4j.PatternLayout
##日志产生时间、具体位置(%l:包括类目名、发生的线程,以及在代码中的行数)、产生的具体日志信息、换行符
log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}  [%l]\:%m%n
 
加载log4j.properties配置文件需要在web.xml中配置一些信息,配置如下:
<context-param>
	<param-name>log4jConfigLocation</param-name>
	<param-value>classpath:log4j.properties</param-value>
</context-param>
<context-param>
	<param-name>log4jRefreshInterval</param-name>
	<param-value>60000</param-value>
</context-param>
 
File文件的路径配置方法:
1.使用绝对路径,把日志文件放到一个固定的位置,例如D:/logs/log.log。
2.使用环境变量:
                      A:${user.home},例如${user.home}/logs/log.log是把日志文件放到个人用户目录下,系统不同位置可能会有差异,以我的电脑系统(win10)和个人配置为例,${user.home}/logs/log.log代表C:\Users\kzhzhang\logs\log.log。
                      B:${catalina.home},例如${catalina.home}/webapps/SM/logs/error.log是把日志文件放到tomcat第一层目录下,${catalina.home}/webapps/SM/logs/error.log这样配置是为了把日志文件放到发布到tomcat下的项目内部。
                      C:${webApp.root},例如${webApp.root}/logs/error.log是把日志文件放到发布到tomcat下的项目内部,与B的例子效果一样;使用这个变量需要在web.xml中配置一些信息,配置如下,
<context-param>  
     <param-name>webAppRootKey</param-name>  
     <param-value>webApp.root</param-value>  
</context-param>
<listener>
      <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
 
Spring通过org.springframework.web.util.WebAppRootListener 这个监听器来监听运行时的项目路径,如果不定义webAppRootKey参数,那么webAppRootKey的值默认为"webapp.root"。
3.设置一个监听器实现ServletContextListener,在项目启动的时候初始化日志保存目录:
package www.tongmap.cn.utils;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

public class Log4jListener implements ServletContextListener{
 public static final String log4jDir = "log4jdir";  
 @Override
 public void contextInitialized(ServletContextEvent sce) {
  String log4jdir = sce.getServletContext().getRealPath("/") + "logs\\";
     System.setProperty(log4jDir, log4jdir); 
 }

 @Override
 public void contextDestroyed(ServletContextEvent sce) {
  System.getProperties().remove(log4jDir);
 }

}
 
 
在log4j.properties文件中使用log4dir(变量名称可以随便命名,注意保持一致)变量配置日志文件位置,例如${log4jdir}/log.log,另外还需要在web.xml中配置监听器,配置如下:
<listener>  
     <listener-class>www.tongmap.cn.utils.Log4jListener</listener-class>  
</listener>
 
ConversionPattern参数的格式含义
格式名 含义
%c 输出日志信息所属的类的全名
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd HH:mm:ss },输出类似:2002-10-18- 22:10:28
%f 输出日志信息所属的类的类名
%l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行
%m 输出代码中指定的信息,如log(message)中的message
%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推
%r 输出自应用启动到输出该日志信息所耗费的毫秒数
%t 输出产生该日志事件的线程名

相关推荐