有效Log4j按指定级别定向输出日志到指定的输出文件地址配置Threshold,log4j中如何屏蔽父logger输出源rootlogger的additivity配置,log4j向多个文件记录日志
关键配置,指定想要的日志级别信息输出到指定的日志文件中:
- log4j.appender.errorLogger.Threshold=ERROR
- #扩展,可指定只在子类自己的输出源中输出,不在父类的输出源中输出
- log4j.additivity.errorLogger=false
additivity配置例子参考log4j配置文件中的additivity属性,additivity配置详细log4j additivity解说
- log4j.logger.com.sgcc=debug, platform1
- log4j.additivity.com.sgcc.test.p2=false
- log4j.logger.com.sgcc.test.p1=debug, platform2
- log4j.logger.com.sgcc.test.p2=debug, platform3
完整配置:
# 定义缺省的日志级别和输出对象
log4j.rootLogger=INFO,console,errorLogger,corLogger
- #制定logger的名字,用于外部获取此logger
- #log4j.logger.tracer=DEBUG,tracer
- log4j.logger.errorLogger=ERROR,errorLogger
- log4j.logger.corLogger=INFO,corLogger
- # 设定错误日志文件的输出模式
- log4j.appender.errorLogger=org.apache.log4j.DailyRollingFileAppender
- log4j.appender.errorLogger.File=${log.home}/core/error.log
- log4j.appender.errorLogger.Threshold=ERROR
- log4j.appender.errorLogger.layout=org.apache.log4j.PatternLayout
- log4j.appender.errorLogger.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] [%c{1}] %X{uidMDC} %m%n
- # 设定审计日志文件的输出模式
- log4j.appender.corLogger=org.apache.log4j.DailyRollingFileAppender
- log4j.appender.corLogger.File=${log.home}/core/cor.log
- log4j.appender.corLogger.layout=org.apache.log4j.PatternLayout
- log4j.appender.corLogger.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] [%c{1}] %X{uidMDC} %m%n
- # 设定跟踪日志文件的输出模式
- #log4j.appender.tracer=org.apache.log4j.DailyRollingFileAppender
- #log4j.appender.tracer.File=${log.home}/core/tracer.log
- #log4j.appender.tracer.layout=org.apache.log4j.PatternLayout
- #log4j.appender.tracer.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] [%c{1}] %X{uidMDC} %m%n
可是上面,还是上面指定控制还不是完美控制的,因为log4j记录器默认可输出的级别在输出日志信息级别以上的话都会输出,因为ERROR比INFO、DEBUG等级别高,所以想要INFO级别的日志信息输出到info.log日志文件中、DEBUG级别的日志信息输出到debug.log日志文件中等这样的需要话。需要重写log4j appender类。看代码:
新建一个类:
- package com.core.util;
- import org.apache.log4j.DailyRollingFileAppender;
- import org.apache.log4j.Priority;
- public class ICoreDailyRollingFileAppender extends DailyRollingFileAppender {
- @Override
- public boolean isAsSevereAsThreshold(Priority priority) {
- return this.getThreshold().equals(priority);
- }
- }
再到log4j.porperties文件中配置:
- # 定义缺省的日志级别和输出对象
- log4j.rootLogger=INFO,console,errorLogger,corLogger
- #制定logger的名字,用于外部获取此logger
- #log4j.logger.tracer=DEBUG,tracer
- log4j.logger.errorLogger=ERROR,errorLogger
- log4j.logger.corLogger=INFO,corLogger
- # 设定错误日志文件的输出模式
- log4j.appender.errorLogger=com.core.util.ICoreDailyRollingFileAppender
- log4j.appender.errorLogger.File=${log.home}/core/error.log
- log4j.appender.errorLogger.Threshold=ERROR
- log4j.appender.errorLogger.layout=org.apache.log4j.PatternLayout
- log4j.appender.errorLogger.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] [%c{1}] %X{uidMDC} %m%n
- # 设定审计日志文件的输出模式
- log4j.appender.corLogger=com.core.util.ICoreDailyRollingFileAppender
- log4j.appender.corLogger.File=${log.home}/core/cor.log
- log4j.appender.corLogger.layout=org.apache.log4j.PatternLayout
- log4j.appender.corLogger.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] [%c{1}] %X{uidMDC} %m%n
- # 设定跟踪日志文件的输出模式
- #log4j.appender.tracer=com.core.util.ICoreDailyRollingFileAppender
- #log4j.appender.tracer.File=${log.home}/core/tracer.log
- #log4j.appender.tracer.layout=org.apache.log4j.PatternLayout
- #log4j.appender.tracer.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} [%-5p] [%c{1}] %X{uidMDC} %m%n
OK,
参考:
Log4j按级别输出日志到不同文件配置分析- http://blog.csdn.net/projava/article/details/7344839
有效Log4j按指定级别定向输出日志到指定的输出文件地址配置Threshold,log4j中如何屏蔽父logger输出源rootlogger的additivity配置,log4j向多个文件记录日志的更多相关文章
- log4j设置,以及中文乱码,通过过滤器输出指定级别的日志,或者指定级别范围的日志
配置文件为默认名字log4j.properties时,放在某个模块下的resources下即可,即使有多个模块的情况下,任意一个模块的resources下有这个默认名字的文件log4j.propert ...
- Log4j 配置某个类中某个方法的输出日志到指定文件
我们在项目中使用log4j开发的时候,会遇到一些特殊的情况,比如:要输出某个类中某个方法的日志信息到文件中,方便以后查看 可以使用如下配置: log4j.rootLogger=info,stdout ...
- springboot输出日志到指定目录,简单粗暴,springboot输出mybatis日志
springboot官方文档地址https://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/htmlsingle/#boot- ...
- SiftingAppender logback 动态 输出 日志 到指定日志文件
SiftingAppender https://www.mkyong.com/logging/logback-different-log-file-for-each-thread/
- (转)log4j(二)——如何控制日志信息的输出?
一:测试环境与log4j(一)——为什么要使用log4j?一样,这里不再重述 1 先看栗子再来下结论 import org.apache.log4j.*; import test.log4j.bean ...
- log4j(二)——如何控制日志信息的输出?
一:测试环境与log4j(一)——为什么要使用log4j?一样,这里不再重述 二:先看栗子再来下结论 import org.apache.log4j.*; import test.log4j.bean ...
- log4j不输出日志错误分析
1.rootLogger不输出 代码如下: 配置文件代码: log4j.rootLogger=info, R,userLog log4j.appender.R=org.apache.log4j.Rol ...
- 解决Flink输出日志中时间比当前时间晚8个小时的问题
Flink安装在CentOS7上,默认时间是UTC时间,查看Flink日志,发现输出时间比当前时间晚8个小时. 通过如下命令,调整成北京时间 cp /usr/share/zoneinfo/Asia/S ...
- ASP.NET Core 集成测试中通过 Serilog 向控制台输出日志
日志是程序员的雷达,不仅在生产环境中需要,在集成测试环境中也需要,可以在持续集成失败后帮助定位问题.与生产环境不同,在集成测试环境中使用控制台输出日志更方便,这样可以通过持续集成 runner 执行 ...
随机推荐
- 再有人问你synchronized是什么,就把这篇文章发给他
在再有人问你Java内存模型是什么,就把这篇文章发给他.中我们曾经介绍过,Java语言为了解决并发编程中存在的原子性.可见性和有序性问题,提供了一系列和并发处理相关的关键字,比如synchronize ...
- 使用SGD(Stochastic Gradient Descent)进行大规模机器学习
原贴地址:http://fuliang.iteye.com/blog/1482002 其它参考资料:http://en.wikipedia.org/wiki/Stochastic_gradient_ ...
- 解析KML文件并提取coordinates中的经纬度坐标信息
从googleEarh导出的kml文件 <?xml version="1.0" encoding="UTF-8"?><kml xmlns=&q ...
- iOS开发-Quartz2D初识
Quartz2D如果单独的从Quartz,那么会发现Quartz是一个开源的Java作业调度框架,单独从英文翻译的角度来看的话Quartz的英文是石英,如果有的时候不小心搜索会发现手表推荐.本文中介绍 ...
- iframe跨域与session失效问题
何为跨域跨域session/cookie? 也就是第三方session/cookie.第一方session/cookie指的是访客当前访问的网站给访客的浏览器设置的seesion /cookie, 会 ...
- 彻底解决 intellij IDEA 卡顿 优化笔记
由于工作中经常出现分支各种切换,使用Eclipse便不再像以前那么舒服了,不停的修改工作空间,每次修改完工作空间又是一堆一堆的个性化设置,来回的切换,真的很累.我们做软件的,怎么能不去尝试新鲜的呢,毕 ...
- [Backbone]5. Model & View, toggle between Models and Views -- 2
Dr. Goodparts is pretty flaky and has been cancelling a lot of appointments lately. He's asked for a ...
- 5种调优Java NIO和NIO.2的方式
Java NIO(New Input/Output)——新的输入/输出API包——是2002年引入到J2SE 1.4里的.Java NIO的目标是提高Java平台上的I/O密集型任务的性能.过了十年, ...
- java 反射获取属性值 方法
public static void main(String[] args) throws SecurityException, ClassNotFoundException, IllegalArgu ...
- window中findstr命令的用法
http://www.netingcn.com/window-findstr-command.html findstr是window系统自带的命令,用途是查找指定的一个或多个文件文件中包含(或通过参数 ...