码迷,mamicode.com
首页 > 编程语言 > 详细

Java日志学习笔记

时间:2016-04-10 19:18:47      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:

一.日志家族

Log4j一开始就很强大,在jdk自带日志系统之前,apache就曾经尝试把log4j划为java的一部分,不知为何没能成功,sun还是用了自己很弱的日志系统。为了兼容各个日志系统,apache又推出了commons-logging,来对多个日志系统进行封装。Commons-logging本身不是日志系统,它只是一个日志系统大管家,来决定到底叫哪一个日志系统出马。由于它使用了ClassLoader寻找和载入底层的日志库,导致了象OSGI这样的框架无法正常工作,因为OSGI的不同的插件使用自己的ClassLoader。OSGI的这种机制保证了插件互相独立,然而却使Apache Common-Logging无法工作。为此人们创造了slf4j,它在编译时静态绑定真正的Log库,因此可以再OSGI中使用。所以,commons-logging跟slf4j是同一类东西,他们之间存在竞争。Log4j的创始人又整了一个logback,性能超越了log4j,但是log4j 2.0似乎又反超了logback。Log4j 2.0相对于log4j变化很多,最突出的一点就是配置文件放弃properties,改用xml或者json。虽然commons-logging与slf4j都只相当于一个大管家,但他们给人的感觉像是一种独立的日志系统,除了使用第三方的日志系统,这两个大管家也拥有自带的简易日志系统,一般只做测试用。于是人们编写了很多jar包作为这些日志系统之间转换的桥梁。

从网上下载的日志库,目录下有好多jar文件,要有选择的使用,不要全部导入,重则出错,轻则占用空间白费事。推荐使用log4j 2.0+slf4j组合,log4j2.0 包括api和core两个包,为了兼容过去的log4j,有一个兼容包log4j-1.2-api-2.5.jar;slf4j核心只包括一个包api,为了让它跟log4j 2.0搭配,需要slf4j到log4j的桥梁包,如果让它跟它自带的简易的日志系统搭配就要导入simple包。

Log4j2.0典型代码:

import org.apache.logging.log4j.Level;

import org.apache.logging.log4j.LogManager;

import org.apache.logging.log4j.Logger; 

static Logger logger = LogManager.getLogger(Hello.class.getName());

Log4j的典型代码:

import org.apache.log4j.Logger;

private static Logger logger = Logger.getLogger(Test.class);  

Log4j2.0的典型配置文件:

<?xml version="1.0" encoding="UTF-8"?>  

  <configuration status="OFF">  

    <appenders>  

      <Console name="Console" target="SYSTEM_OUT">          <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>  

      </Console>  

    </appenders>  

  <loggers>  

    <root level="trace">  

      <appender-ref ref="Console"/>  

    </root>  

  </loggers>  

</configuration>

二.Log4j系统三大部分
    Log4j由三个重要的组成构成:日志记录器(Loggers),输出端(Appenders)和日志格式化器(Layout)。

     level 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者您定义的级别。Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。比如在这里定 义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来。 

     appenderName就是指B日志信息输出到哪个地方。Log4j提供的appender有以下几种:

org.apache.log4j.ConsoleAppender(控制台),  

org.apache.log4j.FileAppender(文件),  

org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件),  

org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件),  

org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

     Log4j提供的layout有以下几种:

org.apache.log4j.HTMLLayout(以HTML表格形式布局),  

org.apache.log4j.PatternLayout(可以灵活地指定布局模式),  

org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),  

org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

三.输出格式

%m 输出代码中指定的消息

%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL  

%r 输出自应用启动到输出该log信息耗费的毫秒数  

%c 输出所属的类目,通常就是所在类的全名  

%t 输出产生该日志事件的线程名  

%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”  

%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921  

%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。

四.关于log4j 2.0的配置

在log4j core包下,解压jar包即可见xsd和dtd文件,这些文件定义了配置文件的一些格式,官网上的示例都没有写出DOCTYPE属性,导致无法使用自动提示功能。关于这个问题,见我博客:http://www.cnblogs.com/weidiao/p/5374824.html

Java日志学习笔记

标签:

原文地址:http://www.cnblogs.com/weidiao/p/5374845.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!