需求:项目过多,多项目生成的日记文件堆积在一起,不方便查看,现修改为每个项目生成自己的日记文件,便于查看。生成的日志文件要求在Tomcat服务器的logs文件夹中。(路径可自己更换)
首先log4j的配置我在这里就不多讲了,导入相关的jar包,创建相关的配置文件就以了。
项目用的是log4j.properties文件。我就直接上配置文件了,代码中均有注释说明
### 指定日志根logger ###
log4j.rootLogger = INFO , stdout, D, E
### output to the console ###
#输出到控制台
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
#日志模板
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
#日志格式化输出
log4j.appender.stdout.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
### Output to the log file ###
#每天生成一个文件
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
#日志文件打印路径(主要看此处的配置,将日志生成到了tomcat文件夹中)
log4j.appender.D.File = ../logs/CSS_logs.log
#是否在日记后面追加,false覆盖
log4j.appender.D.Append = true
#指定日志级别
log4j.appender.D.Threshold = DEBUG
#日志编码
log4j.appender.D.Encoding=UTF-8
#文件名日期格式
log4j.appender.D.DatePattern=yyyy-MM-dd'.log'
#日志模板
log4j.appender.D.layout = org.apache.log4j.PatternLayout
#日志格式化输出方式
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
### 错误输出到日志文件 ###
log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
## 错误日志文件
log4j.appender.E.File =../logs/CSS_error.log
## 日志附加到文件末尾
log4j.appender.E.Append = true
log4j.appender.E.DatePattern=yyyy-MM-dd'.log'
## 只输出ERROR级别(优先级)以上的日志 ##
log4j.appender.E.Threshold = ERROR
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} - [ %t:%r ] - [ %p ] - %m%n
log4j.appender.E.Encoding=utf-8
###输出SQL
##所有com.ibatis 包下日志级别为debug
log4j.logger.com.ibatis=DEBUG
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=DEBUG
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=DEBUG
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG
log4j.logger.Java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
#druid sql Record
log4j.logger.druid.sql=warn,stdout
log4j.logger.druid.sql.DataSource=warn,stdout
log4j.logger.druid.sql.Connection=warn,stdout
log4j.logger.druid.sql.Statement=warn,stdout
log4j.logger.druid.sql.ResultSet=warn,stdout
主要使用的地方做一下说明:
首先注释为:###输出SQL、#druid sql Record两处示项目而定,你们可以不用看。
注释为:### Output to the log file ###以及### 错误输出到日志文件 ###为生成日记文件的主要配置。
第一个主要设定了等级为DEBUG以下级别的都输出至日志中
第二个主要设定了等级为ERROR以下级别的都输出至日志中
日志输出路径使用log4j.appender.E.File进行设置。
例如:CSS_error.log,CSS为我的项目名称。
说明:假如今天为1号,日志会生成CSS_error.log,明日为2号,日记会将1号的日志文件名更改为CSS_error.log2019-09-01.log