JAVA 日志系统【 logback]

Logback浅析

一、Logback为取代log4j而生html

     Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分红三个模块:logback-core,logback- classic和logback-access。spring

二、Logback的核心对象:Logger、Appender、Layout数据库

     Logback主要创建于LoggerAppender  Layout 这三个类之上。
apache

     Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也能够定义日志类型、级别。Logger对象通常多定义为静态常量,如:api

复制代码

 1 package com.logs; 2  3 import org.slf4j.Logger; 4 import org.slf4j.LoggerFactory; 5  6 public class MyApp { 7     final static Logger logger = LoggerFactory.getLogger("MyApp.class"); 8     public static void main(String[] args) { 9         10         logger.trace("trace");11         logger.debug("debug str");12         logger.info("info str");13         logger.warn("warn");14         logger.error("error");15     }16 }

复制代码

     Appender:用于指定日志输出的目的地,目的地能够是控制台、文件、远程套接字服务器、 MySQL、 PostreSQL、Oracle和其余数据库、 JMS和远程UNIX Syslog守护进程等。服务器

     Layout:负责把事件转换成字符串,格式化的日志信息的输出。具体的Layout通配符,能够直接查看帮助文档。框架

三、Level 有效级别lua

    Logger能够被分配级别。级别包括:TRACE、DEBUG、INFO、WARN和ERROR,定义于ch.qos.logback.classic.Level类。程序会打印高于或等于所设置级别的日志,设置的日志等级越高,打印出来的日志就越少。若是设置级别为INFO,则优先级高于等于INFO级别(如:INFO、 WARN、ERROR)的日志信息将能够被输出,小于该级别的如DEBUG将不会被输出。为确保全部logger都可以最终继承一个级别,根logger老是有级别,默认状况下,这个级别是DEBUG。spa

四、 三值逻辑hibernate

   Logback的过滤器基于三值逻辑(ternary logic),容许把它们组装或成链,从而组成任意的复合过滤策略。过滤器很大程度上受到Linux的iptables启发。这里的所谓三值逻辑是说,过滤器的返回值只能是ACCEPT、DENY和NEUTRAL的其中一个。

若是返回DENY,那么记录事件当即被抛弃,再也不通过剩余过滤器;

若是返回NEUTRAL,那么有序列表里的下一个过滤器会接着处理记录事件;

若是返回ACCEPT,那么记录事件被当即处理,再也不通过剩余过滤器。

五、Filter 过滤器

    Logback-classic提供两种类型的过滤器:常规过滤器和TuroboFilter过滤器。Logback总体流程:Logger 产生日志信息;Layout修饰这条msg的显示格式;Filter过滤显示的内容;Appender具体的显示,即保存这日志信息的地方。

六、具体使用案例

     Java项目中通常都会应用好比struts、spring、hibernate等开源框架,而这些框架不少是应用log4j记录日志的,因此咱们考虑用log4j + slf4j + logback 。这样咱们须要导入log4j-over-slf4j-1.6.4.jar 、logback-classic-1.0.1.jar 、logback-core-1.0.1.jar 、slf4j-api-1.6.4.jar ,若是你要用到EvaluatorFilter过滤器来过滤日志Msg中的特殊字符须要导入其依赖包 janino-2.3.2.jar。其logback.xml


Logback浅析
一、Logback为取代log4j而生
     Logback是由log4j创始人Ceki Gülcü设计的又一个开源日志组件。logback当前分红三个模块:logback-core,logback- classic和logback-access。
二、Logback的核心对象:Logger、Appender、Layout
     Logback主要创建于Logger、Appender 和 Layout 这三个类之上。
     Logger:日志的记录器,把它关联到应用的对应的context上后,主要用于存放日志对象,也能够定义日志类型、级别。Logger对象通常多定义为静态常量,如:
 1 package com.logs; 2  3 import org.slf4j.Logger; 4 import org.slf4j.LoggerFactory; 5  6 public class MyApp { 7     final static Logger logger = LoggerFactory.getLogger("MyApp.class"); 8     public static void main(String[] args) { 9         10         logger.trace("trace");11         logger.debug("debug str");12         logger.info("info str");13         logger.warn("warn");14         logger.error("error");15     }16 }
     Appender:用于指定日志输出的目的地,目的地能够是控制台、文件、远程套接字服务器、 MySQL、 PostreSQL、Oracle和其余数据库、 JMS和远程UNIX Syslog守护进程等。
     Layout:负责把事件转换成字符串,格式化的日志信息的输出。具体的Layout通配符,能够直接查看帮助文档。
三、Level 有效级别
    Logger能够被分配级别。级别包括:TRACE、DEBUG、INFO、WARN和ERROR,定义于ch.qos.logback.classic.Level类。程序会打印高于或等于所设置级别的日志,设置的日志等级越高,打印出来的日志就越少。若是设置级别为INFO,则优先级高于等于INFO级别(如:INFO、 WARN、ERROR)的日志信息将能够被输出,小于该级别的如DEBUG将不会被输出。为确保全部logger都可以最终继承一个级别,根logger老是有级别,默认状况下,这个级别是DEBUG。
四、 三值逻辑
   Logback的过滤器基于三值逻辑(ternary logic),容许把它们组装或成链,从而组成任意的复合过滤策略。过滤器很大程度上受到Linux的iptables启发。这里的所谓三值逻辑是说,过滤器的返回值只能是ACCEPT、DENY和NEUTRAL的其中一个。
若是返回DENY,那么记录事件当即被抛弃,再也不通过剩余过滤器;
若是返回NEUTRAL,那么有序列表里的下一个过滤器会接着处理记录事件;
若是返回ACCEPT,那么记录事件被当即处理,再也不通过剩余过滤器。
五、Filter 过滤器
    Logback-classic提供两种类型的过滤器:常规过滤器和TuroboFilter过滤器。Logback总体流程:Logger 产生日志信息;Layout修饰这条msg的显示格式;Filter过滤显示的内容;Appender具体的显示,即保存这日志信息的地方。
相关文章
相关标签/搜索