log4j配置多个日志文件,输出特定的日志信息

来源:互联网 发布:易语言用数据库做登录 编辑:程序博客网 时间:2024/05/06 13:06

在实际应用中,有需求要输出某些特定的日志信息,需要形成单独的日志文件。

可以通过配置log4j来解决这个问题:

1、先看一个常见的log4j.properties文件,它是在控制台和daily.log文件中记录日志:
log4j.rootLogger=error,dailyLog,stdoutlog4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.Target=System.outlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%nlog4j.appender.dailyLog=org.apache.log4j.DailyRollingFileAppenderlog4j.appender.dailyLog.File=../logs/daily.loglog4j.appender.dailyLog.Append=truelog4j.appender.dailyLog.Threshold=ERRORlog4j.appender.dailyLog.DatePattern='.'yyyy-MM-ddlog4j.appender.dailyLog.layout=org.apache.log4j.PatternLayoutlog4j.appender.dailyLog.layout.ConversionPattern=%5p:%d - %m%n

2、如果想对不同的功能模块输出不同的文件,怎么操作?
如:
用户基础信息模块路径为:com.isoft.visa.baseinf
它下面有个类:com.isoft.visa.baseinf.service.impl.UserInfo
private Log log = LogFactory.getLog(UserInfo.class);
然后在log4j.properties中加入:
log4j.logger.com.isoft.visa.baseinf=info,userLog,stdoutlog4j.appender.userLog=org.apache.log4j.FileAppenderlog4j.appender.userLog.File=../logs/userinfo.loglog4j.appender.userLog.Append=truelog4j.appender.userLog.Threshold=infolog4j.appender.userLog.layout=org.apache.log4j.PatternLayoutlog4j.appender.userLog.layout.ConversionPattern==%d %p [%c] - %m%n
注:也就是让com.isoft.visa.baseinf模块下所有的logger使用log4j.appender.userLog所做的配置。


3、 自定义“别名”的使用,相当于2的变种。

同上模块:
private Log log = LogFactory.getLog("userInfoLog");
然后在log4j.properties中加入:

log4j.logger.userInfoLog=info,userLog,stdoutlog4j.appender.userLog=org.apache.log4j.FileAppenderlog4j.appender.userLog.File=../logs/userinfo.loglog4j.appender.userLog.Append=truelog4j.appender.userLog.Threshold=infolog4j.appender.userLog.layout=org.apache.log4j.PatternLayoutlog4j.appender.userLog.layout.ConversionPattern==%d %p [%c] - %m%n
注:也就是在用logger时给它一个自定义的名字(如这里的"userInfoLog"),然后在log4j.properties中做出相应配置即可。在这种模式下,即使在同一个类中也能定义多个不同输出的log.
在类中调用代码如下:
private Log loggerError = LogFactory.getLog("userInfoLogError");
private Log loggerInfo = LogFactory.getLog("userInfoLogInfo");
 
4、自定义的日志默认是同时输出到log4j.rootLogger所配置的日志中的,如何能只让它们输出到自己指定的日志中呢?别急,这里有个开关:
  log4j.additivity.userInfoLog = false
  它用来设置是否同时输出到log4j.rootLogger所配置的日志中,设为false就不会输出到其它地方啦!注意这里的"userInfoLog"是你在程序中给logger起的那个自定义的名字!
  如果你说,我只是不想同时输出这个日志到log4j.rootLogger所配置的logfile中,stdout里我还想同时输出呢!那也好办,如:
  log4j.logger.userInfoLog=DEBUG, userLog, stdout
0 0
原创粉丝点击