栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何为log4j设置单独的日志记录流?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何为log4j设置单独的日志记录流?

您可以通过创建自定义日志记录类来设置不同的日志记录行为。

这是我的解决方案:

public abstract class AbstractLogger {    protected Logger log;    protected Class callingClass;    public AbstractLogger(Class c)    {        this.log = LoggerFactory.getLogger(this.getClass());        this.callingClass = c;    }    public void log(String s)    {        log.debug(this.callingClass + " :" + s);    }}public class LoggerOne extends AbstractLogger {    public LoggerOne(Class c) {        super(c);    }}public class LoggerTwo extends AbstractLogger {    public LoggerTwo(Class c) {        super(c);    }}public class LoggerThree extends AbstractLogger {    public LoggerThree(Class c) {        super(c);    }    }

在Log4j.properties中设置

#Define custom levels by package#set to ERROR to turn them offlog4j.logger.org.myproject.loggers.LoggerOne=ERRORlog4j.logger.org.myproject.loggers.LoggerTwo=DEBUGlog4j.logger.org.myproject.loggers.LoggerThree=DEBUG

使用这些记录器时:

要使用这些记录器:

 public class MyMain {    // private Logger log = LoggerFactory.getLogger(MyMain.class);     private AbstractLogger l1= new LoggerOne(this.getClass());     private AbstractLogger l2= new LoggerTwo(this.getClass());     private AbstractLogger l3= new LoggerThree(this.getClass());    public void run()    { l1.log("log 1");  long t1 = System.currentTimeMillis();  try {         Thread.sleep(1000);      //1000 milliseconds is one second.     } catch(InterruptedException ex) {         Thread.currentThread().interrupt();     }  long t2 = System.currentTimeMillis();  l2.log("log 2");  l3.log("Foo time taken:" + (t2-t1)/1000);    }    public static void main(String[] args) {        MyMain me = new MyMain();        me.run();    }}

日志输出:

12:27:29 DEBUG LoggerTwo:18 - class maventestspace.MyMain :log 212:27:29 DEBUG LoggerThree:18 - class maventestspace.MyMain :Foo time taken:1

请注意,LoggerOne无法打印,因为在属性文件中将其设置为ERROR。

要重定向这些单独的日志文件,您需要设置新的附加程序和记录器。

log4j.logger.org.myproject.loggers.LoggerOne=DEBUG, file1, stdoutlog4j.logger.org.myproject.loggers.LoggerTwo=DEBUG, file2, stdoutlog4j.logger.org.myproject.loggers.LoggerThree=DEBUG, file3, stdout# Direct log messages to a log filelog4j.appender.file1=org.apache.log4j.RollingFileAppender#log4j.appender.TextProcessor.Threshold=debuglog4j.appender.file1.File=E:\logs\log1.txtlog4j.appender.file1.MaxFileSize=10MBlog4j.appender.file1.MaxBackupIndex=1log4j.appender.file1.layout=org.apache.log4j.PatternLayoutlog4j.appender.file1.layout.ConversionPattern=%d{HH:mm:ss} %-5p %c{1}:%L - %m%n# Direct log messages to a log filelog4j.appender.file2=org.apache.log4j.RollingFileAppender#log4j.appender.TextProcessor.Threshold=debuglog4j.appender.file2.File=E:\logs\log2.txtlog4j.appender.file2.MaxFileSize=10MBlog4j.appender.file2.MaxBackupIndex=1log4j.appender.file2.layout=org.apache.log4j.PatternLayoutlog4j.appender.file2.layout.ConversionPattern=%d{HH:mm:ss} %-5p %c{1}:%L - %m%n# Direct log messages to a log filelog4j.appender.file3=org.apache.log4j.RollingFileAppender#log4j.appender.TextProcessor.Threshold=debuglog4j.appender.file3.File=E:\logs\log3.txtlog4j.appender.file3.MaxFileSize=10MBlog4j.appender.file3.MaxBackupIndex=1log4j.appender.file3.layout=org.apache.log4j.PatternLayoutlog4j.appender.file3.layout.ConversionPattern=%d{HH:mm:ss} %-5p %c{1}:%L - %m%n


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/596165.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号