`
fanjf
  • 浏览: 296288 次
  • 性别: Icon_minigender_1
  • 来自: 安徽
社区版块
存档分类
最新评论

【转】Log4j简单学习笔记

 
阅读更多

log4j结构图:

结构图展现出了log4j的主结构。
logger:表示记录器,即数据来源;
appender:输出源,即输出方式(如:控制台、文件。。.)
layout:输出布局

Logger机滤器:
常用级别的划分:Debug,Info,Warn,Error,Fatal
这5个级别由低到高,如果配置的级别为"INFO"那么"Debug"级别的信息则不会显示"依次类推。

示例代码:

复制代码
@Test
    public void testLevel() {
        log.debug("Debug message");       //调试信息
        log.info("Info message");     //一般信息
        log.warn("Warn message");     //警告信息
        log.error("Error message");       //错误信息
        log.fatal("Fatal message ");      //致命错误信息
    }
复制代码

配置:

#debug 日志级别 stdOut 为输出源
log4j.rootLogger=debug, stdOut
#ConsoleAppender 表示控制台输出
log4j.appender.stdOut=org.apache.log4j.ConsoleAppender
#PatternLayout 默认输出的布局
log4j.appender.stdOut.layout=org.apache.log4j.PatternLayout

运行结果:

如果日志级别为:debug
Debug message
Info message
Warn message
Error message
Fatal message 
如果日志级别为:info
Info message
Warn message
Error message
Fatal message

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

Appender输出源:
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)

1.ConsoleAppender选项:
Threshold=DEBUG:指定日志消息的输出最低层次。(根据优先级别输出Debug以上的信息)
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
encoding=UTF-8:指定编码,默认为操作系统默认编码。
Target=System.err:默认情况下是:System.out,指定输出控制台。

2.FileAppender 选项:
Threshold=DEBUF:指定日志消息的输出最低层次。
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
encoding=UTF-8:指定编码,默认为操作系统默认编码。
File=mylog.txt:指定消息输出到mylog.txt文件。
Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。

3.DailyRollingFileAppender 选项 
Threshold=WARN:指定日志消息的输出最低层次。 
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。 
encoding=UTF-8:指定编码,默认为操作系统默认编码。
File=mylog.txt:指定消息输出到mylog.txt文件。 
Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。 
DatePattern=''.''yyyy-ww:每周滚动一次文件,即每周产生一个新的文件。当然也可以指定按月、周、天、时和分。即对应的格式如下: 
1)''.''yyyy-MM: 每月 
2)''.''yyyy-ww: 每周 
3)''.''yyyy-MM-dd: 每天 
4)''.''yyyy-MM-dd-a: 每天两次 
5)''.''yyyy-MM-dd-HH: 每小时 
6)''.''yyyy-MM-dd-HH-mm: 每分钟

4.RollingFileAppender 选项
Threshold=DEBUG:指定日志消息的输出最低层次。
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
File=mylog.txt:指定消息输出到mylog.txt文件。
Append=false:默认值是true,即将消息增加到指定文件中,false指将消息覆盖指定的文件内容。
MaxFileSize=100KB: 后缀可以是KB, MB 或者是 GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件。
MaxBackupIndex=2:指定可以产生的滚动文件的最大数。

5.WriterAppender选项:
Threshold=DEBUG:指定日志消息的输出最低层次。(根据优先级别输出Debug以上的信息)
ImmediateFlush=true:默认值是true,意谓着所有的消息都会被立即输出。
encoding=UTF-8:指定编码,默认为操作系统默认编码。

Layout输出内容格式:
org.apache.log4j.PatternLayout(可以灵活地指定布局模式,自定义布局),
org.apache.log4j.HTMLLayout(以HTML表格形式布局,纯HTML文本),
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)。

PatternLayout是可自定义格式的,其他三个为系统提供的固定格式。
自定义配置:
log4j.appender.stdOut.layout=org.apache.log4j.PatternLayout
log4j.appender.stdOut.layout.ConversionPattern=%-4r %-5p %d{yyyy-MM-dd HH:mm:ssS} %c %m%n

关于ConversionPattern参数含义的解释:

1.每一部分都以%开头,以空格分隔
2."-"表示左对齐,默认为右对齐
3.%d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy-MM-dd HH:mm:ss,SSS},
4.%r: 输出自应用启动到输出该log信息耗费的毫秒数
5.%t: 输出产生该日志事件的线程名
6.%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
7.%%: 输出一个"%"字符
8.%c: 输出日志信息所属的类目,通常就是所在类的全名
9.%F: 输出日志消息产生时所在的文件名称
10.%L: 输出代码中的行号
11.%m: 输出代码中指定的消息,产生的日志具体信息
12.%l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。
13.%n: 输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"输出日志信息换行
14.在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:
  1)%20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。
  2)%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。
  3)%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。

  配置:log4j.appender.stdOut.layout.ConversionPattern=%20r %d %m%n
  " 0 2013-03-05 10:57:41,546 Debug message"
  配置:log4j.appender.stdOut.layout.ConversionPattern=%-20r %d %m%n
  "0 2013-03-05 10:58:10,875 Debug message"
15.%20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边较远输出的字符截掉,如果是负号则相反。

 

原文链接:Log4j简单学习笔记

分享到:
评论

相关推荐

    log4j 学习 笔记

    log4j学习笔记log4j学习笔记log4j学习笔记log4j学习笔记log4j学习笔记log4j学习笔记log4j学习笔记log4j学习笔记log4j学习笔记

    Log4j 学习笔记.doc

    Log4j 学习笔记. 1. Log4j的类图 2. Logger:日志写出器 1. Logger的输出方法 2. Logger的命名规则 3. Log level 4. 示例代码 5. 关于logger的两点说明 3. Appender:日志目的地 1. ConsoleAppender 2. ...

    Apache_Log4j_学习笔记

    Apache_Log4j_学习笔记

    Log4j2学习log4j2.xml配置模板

    Log4j2学习笔记,引入log4j2的依赖-log4j2.xml配置模板-application.properties文件配置-使用

    Log4j学习笔记和一套完整定义实例

    Log4j学习笔记和一套完整定义实例 精辟

    Log4j入门学习笔记

    pptx格式。Log4j详细讲解。Logger--日志写出器,供程序员输出日志信息 。Log4j 允许开发人员定义多个Logger,每个Logger拥有自己的名字,Logger之间通过名字来表明隶属关系。

    Log4j 学习笔记

    Log4j 学习笔记

    Log4j的学习笔记

    NULL 博文链接:https://greatjone.iteye.com/blog/1161007

    log4j的学习笔记

    关于log4j的一些重点,要点。要用到log4j非常有用的笔记

    log4j使用笔记

    1.该笔记中详细的介绍了log4j的作用和优势、具体地讲解了log4j的使用步骤和详细配置。 2.深入的说明了log4j在项目中的重要地位以及给项目带来的影响,同时说明了log4j的优化。 3.该笔记从log4j的简介/入门开始介绍,到...

    logging-log4j2-log4j-2.15.0-rc2.zip maven 资源库

    针对Log4j 2 远程代码执行漏洞,需要用到的升级资源包,适用于maven资源库,包括log4j,log4j-core,log4j-api,log4j-1.2-api,log4j-jpa等全套2.15.0 maven资源库jar包。如果是maven本地仓库使用,需要将zip包解压...

    log4J学习笔记

    log4j的详细学习笔记,最适合初级、中级学员

    log4j 学习笔记

    log4j 学习笔记 自己整理出来的 网上写的很杂乱。其实在java企业级中开发 我们更重视的是如何做日志记录。本笔记快速入门使用 log4j 节省了企业开发的学习成本

    log4j学习笔记.

    log4j学习笔记.

    不错的 log4j 学习 笔记

    log4j的学习笔记,网上找到的,写的很不错

    log4j.jar各个版本

    apache-log4j-1.2.15.jar, apache-log4j-extras-1.0.jar, apache-log4j-extras-1.1.jar, apache-log4j.jar, log4j-1.2-api-2.0.2-javadoc.jar, log4j-1.2-api-2.0.2-sources.jar, log4j-1.2-api-2.0.2.jar, log4j-...

    Log4J学习笔记

    Log4J学习笔记 1、配置文件 2、数据库 3、封装

    若依框架使用的log4j2.16.0,修复log4j漏洞log4j2下载最新log4j2.16.0下载

    若依框架使用的log4j2.16.0,修复log4j漏洞log4j2下载最新log4j2.16.0下载

Global site tag (gtag.js) - Google Analytics