log4j配置多个日志文件,输出特定的日志信息
2014-12-11 11:43
423 查看
在实际应用中,有需求要输出某些特定的日志信息,需要形成单独的日志文件。
可以通过配置log4j来解决这个问题:
1、先看一个常见的log4j.properties文件,它是在控制台和daily.log文件中记录日志:
2、如果想对不同的功能模块输出不同的文件,怎么操作?
如:
用户基础信息模块路径为:com.isoft.visa.baseinf
它下面有个类:com.isoft.visa.baseinf.service.impl.UserInfo
private Log log = LogFactory.getLog(UserInfo.class);
然后在log4j.properties中加入:
3、 自定义“别名”的使用,相当于2的变种。
同上模块:
private Log log = LogFactory.getLog("userInfoLog");
然后在log4j.properties中加入:
在类中调用代码如下:
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
可以通过配置log4j来解决这个问题:
1、先看一个常见的log4j.properties文件,它是在控制台和daily.log文件中记录日志:
log4j.rootLogger=error,dailyLog,stdout 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{ABSOLUTE} %5p %c{1}:%L - %m%n log4j.appender.dailyLog=org.apache.log4j.DailyRollingFileAppender log4j.appender.dailyLog.File=../logs/daily.log log4j.appender.dailyLog.Append=true log4j.appender.dailyLog.Threshold=ERROR log4j.appender.dailyLog.DatePattern='.'yyyy-MM-dd log4j.appender.dailyLog.layout=org.apache.log4j.PatternLayout log4j.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,stdout log4j.appender.userLog=org.apache.log4j.FileAppender log4j.appender.userLog.File=../logs/userinfo.log log4j.appender.userLog.Append=true log4j.appender.userLog.Threshold=info log4j.appender.userLog.layout=org.apache.log4j.PatternLayout log4j.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,stdout log4j.appender.userLog=org.apache.log4j.FileAppender log4j.appender.userLog.File=../logs/userinfo.log log4j.appender.userLog.Append=true log4j.appender.userLog.Threshold=info log4j.appender.userLog.layout=org.apache.log4j.PatternLayout log4j.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
相关文章推荐
- log4j日志信息输出文件配置
- [转载]log4j输出多个自定义日志文件,动态配置路径
- log4j输出多个自定义日志文件,动态配置路径
- log4j异步文件日志输出配置
- Log4j按级别输出日志到不同文件配置分析
- 配置log4j输出指定类中的日志信息到指定的位置
- log4j输出多个自定义日志文件,动态配置路径[转]
- log4j中用变量配置日志输出文件位置
- log4j输出多个自定义日志文件,动态配置路径
- LOG4J的配置..实现了输出到控制台、文件、回滚文件、发送日志邮件
- Log4j按级别输出日志到不同文件配置分析
- log4j输出多个自定义日志文件,动态配置路径
- log4j输出多个自定义路径的日志文件,动态配置路径
- log4j输出多个自定义日志文件,动态配置路径
- log4j高级技巧--动态配置日志输出文件的位置
- .LOG4J的配置(输出到控制台、文件、回滚文件、发送日志邮件、输出到数据库日志表、自定义标签等全套功能)
- ibatis配置log4j输出sql语句等日志信息
- ibatis配置log4j输出sql语句等日志信息
- log4j输出多个自定义日志文件,动态配置路径
- log4j输出多个自定义日志文件,动态配置路径[转]