java日志框架系列(5):logback框架appender详解
1.appender
1.什么是appender
2.AppenderBase
public synchronized void doAppend(E eventObject) { // prevent re-entry. if (guard) { return; } try { guard = true; if (!this.started) { if (statusRepeatCount++ < ALLOWED_REPEATS) { addStatus(new WarnStatus( "Attempted to append to non started appender [" + name + "].", this)); } return; } if (getFilterChainDecision(eventObject) == FilterReply.DENY) { return; } // ok, we now invoke derived class' implementation of append this.append(eventObject); } catch (Exception e) { if (exceptionCount++ < ALLOWED_REPEATS) { addError("Appender [" + name + "] failed to append.", e); } } finally { guard = false; } }
通过代码可以知道AppenderBase类是的doAppender()是同步线程安全的;并不是所有时候都需要同步,因此当不需要同步的时候可以使用UnsynchronizedAppenderBase类。
3. logback-core
logback-core模块是logback的基础。下面讲解一下可以直接使用的appender。
1.logback-core模块中的appender
logback-core模块中的appender种类:OutputStreamAppender、ConsoleAppender、FileAppender、RollingFileAppender。
你有没有发现:logback-core中的appender的目的地都是本地啊,那有没有可以发送到网络上的appender呀,当然有,在logback-classic模块中,下一节介绍。
这些appender之间的关系如下所示:
1.OutputStreamAppender讲解
2.ConsoleAppender讲解
这些属性是需要配置的,因此我们可以通过在xml配置文件中的<appender>标签中创建以属性名为标签名的标签,并为这些标签进行配置。
注意:<appender>中不同的class属性值表明使用不同的目的地,因此会有不同的参数,从而表现出在配置文件中的标签有所差异。
3.FileAppender讲解
这些属性是需要配置的,因此我们可以通过在xml配置文件中的<appender>标签中创建以属性名为标签名的标签,并为这些标签进行配置。
注意:<appender>中不同的class属性值表明使用不同的目的地,因此会有不同的参数,从而表现出在配置文件中的标签有所差异。
4.RollingFIleAppender讲解
1.实现滚动记录原理
这些属性是需要配置的,因此我们可以通过在xml配置文件中的<appender>标签中创建以属性名为标签名的标签,并为这些标签进行配置。
注意:<appender>中不同的class属性值表明使用不同的目的地,因此会有不同的参数,从而表现出在配置文件中的标签有所差异。
1.最受欢迎的滚动策略TimeBaseRollingPolicy
下面讲解一下fileNamePattern的部分值及作用:
注意:所有“\”和“/”都被解释为目录分隔符。任何需要的目录都会被创建。所以你可以轻松地把记录文件放到不同的目录。
4.logback-classic
在logback-classic模块中也存在一些appender,并且这些appender的目的地不是本地。下面详细了解一下这些appender。
logback-classic模块中的appender分类:SocketAppender、DBAppender、SMTPAppender、SyslogAppender、SiftingAppender以及基于JMS的两种Appender(JMSTopicAppender和JMSQueueAppender,他们继承自JMSAppenderBase类);提供了总共7种appender;另外还可以自定义appender,需要通过继承AppenderBase来实现自定义的appender。