客服:点击这里给我发消息

手机:15193566610 马先生

奈特网络科技,武威网站建设公司

您的位置:当前位置:武威网站-甘肃奈特网 > 网站建设 > 建站知识 >

Log4j学习笔记(1)_log4j 基础架构&配置项解析

来源:未知   发表时间:2015-11-10 10:48

    Log4j学习笔记(1)_log4j 基础架构&配置项解析

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

    1.日志记录器(Loggers):控制要输出哪些日志记录语句,对日志信息进行级别限制。

    2.输出端(Appenders):指定了日志将打印到控制台还是文件中。

    3.日志格式化器(Layout):控制日志信息的显示格式。

    类图结构如下,主要分为三部分:

    配置文件解析

    1.配置根Logger

    其语法为:log4j.rootLogger = [ level ] , [appenderName], [appenderName], …

    Log4j建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。通过在这里定义的级别,您可以控制到应用程序中相应级别的日志信息的开关。比如在这里定 义了INFO级别,则应用程序中所有DEBUG级别的日志信息将不被打印出来。 appenderName就是指日志信息输出到哪个地方。您可以同时指定多个输出目的地。

    2.配置Appender(日志信息输出目的地)

    其语法为:log4j.appender.[appenderName] = [appenderType]

    其中,Log4j提供的appender有以下几种:

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

    org.apache.log4j.FileAppender(文件)

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

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

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

    3.配置日志信息的格式(布局)

    其语法为:log4j.appender.[appenderName].layout = [layoutType]

    (1)Log4j提供的layout有以下几种:

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

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

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

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

    (2)Log4J采用类似C语言中的printf函数的打印格式格式化日志信息,打印参数如下: %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 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)

    Log4j实战:log4j配置示例&Spring集成log4j

    参考文章:

    1.Log4J使用笔记 http://www.cnblogs.com/eflylab/archive/2007/01/11/618001.html

    2.Log4j详解与实战 http://www.iteye.com/topic/378077