`
liqita
  • 浏览: 291284 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Log4J.xml配置详解

 
阅读更多

Appender

Appender:日志输出器,配置日志的输出级别、输出位置等,包括以下几类:

 

ConsoleAppender: 日志输出到控制台;

FileAppender:输出到文件;

RollingFileAppender:输出到文件,文件达到一定阈值时,自动备份日志文件;

DailyRollingFileAppender:可定期备份日志文件,默认一天一个文件,也可设置为每分钟一个、每小时一个;

WriterAppender:可自定义日志输出位置。

配置日志信息输出目的地

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

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

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

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

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

 

日志级别

一般日志级别包括:ALL,DEBUG, INFO, WARN, ERROR,FATAL,OFF

Log4J推荐使用:DEBUG, INFO, WARN, ERROR

输出级别的种类:

OFF 为最高等级 关闭了日志信息  

FATAL  为可能导致应用中止的严重事件错误  

ERROR 为严重错误 主要是程序的错误  

WARN 为一般警告,比如session丢失  

INFO 为一般要显示的信息,比如登录登出  

DEBUG 为程序的调试信息  

TRACE 为比DEBUG更细粒度的事件信息  

ALL 为最低等级,将打开所有级别的日志 

输出格式

Log4J最常用的日志输出格式为:org.apache.log4j.PatternLayOut,其主要参数为:

 

%n - 换行

%m - 日志内容

%p - 日志级别(FATAL, ERROR,WARN, INFO,DEBUG or custom)

%r - 程序启动到现在的毫秒数

%t - 当前线程名

%d - 日期和时间, 一般使用格式 %d{yyyy-MM-dd HH:mm:ss, SSS}

%l - 输出日志事件的发生位置, 同 %F%L%C%M

%F - java 源文件名

%L - java 源码行数

%C - java 类名,%C{1} 输出最后一个元素

%M - java 方法名

配置日志信息的格式

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

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

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

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

日志信息格式中几个符号所代表的含义:

-X号: X信息输出时左对齐;  

%p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,  

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

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

%c: 输出日志信息所属的类目,通常就是所在类的全名  

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

%l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main (TestLog4.java:10)  

%x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。  

%%: 输出一个"%"字符  

%F: 输出日志消息产生时所在的文件名称  

%L: 输出代码中的行号  

%m: 输出代码中指定的消息,产生的日志具体信息  

%n: 输出一个回车换行符,Windows平台为"/r/n",Unix平台为"/n"输出日志信息换行  

可以在%与模式字符之间加上修饰符来控制其最小宽度、最大宽度、和文本的对齐方式。如:  

1)%20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。  

2)%-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。  

3)%.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。  

4)%20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边较远输出的字符截掉。

 

代码示例

 

代码示例

示例一:

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

<!DOCTYPE log4j:configuration PUBLIC "-//log4j/log4j Configuration//EN" "log4j.dtd">

 

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

 

    <!-- 日志输出到控制台 -->

    <appender name="console" class="org.apache.log4j.ConsoleAppender">

        <!-- 日志输出格式 -->

        <layout class="org.apache.log4j.PatternLayout">

            <param name="ConversionPattern" value="[%p][%d{yyyy-MM-dd HH:mm:ss SSS}][%c]-[%m]%n"/>

        </layout>

 

        <!--过滤器设置输出的级别-->

        <filter class="org.apache.log4j.varia.LevelRangeFilter">

            <!-- 设置日志输出的最小级别 -->

            <param name="levelMin" value="INFO"/>

            <!-- 设置日志输出的最大级别 -->

            <param name="levelMax" value="ERROR"/>

        </filter>

    </appender>

 

 

    <!-- 输出日志到文件 -->

    <appender name="fileAppender" class="org.apache.log4j.FileAppender">

        <!-- 输出文件全路径名-->

        <param name="File" value="/data/applogs/own/fileAppender.log"/>

        <!--是否在已存在的文件追加写:默认时true,若为false则每次启动都会删除并重新新建文件-->

        <param name="Append" value="false"/>

        <param name="Threshold" value="INFO"/>

        <!--是否启用缓存,默认false-->

        <param name="BufferedIO" value="false"/>

        <!--缓存大小,依赖上一个参数(bufferedIO), 默认缓存大小8K  -->

        <param name="BufferSize" value="512"/>

        <!-- 日志输出格式 -->

        <layout class="org.apache.log4j.PatternLayout">

            <param name="ConversionPattern" value="[%p][%d{yyyy-MM-dd HH:mm:ss SSS}][%c]-[%m]%n"/>

        </layout>

    </appender>

 

 

    <!-- 输出日志到文件,当文件大小达到一定阈值时,自动备份 -->

    <!-- FileAppender子类 -->

    <appender name="rollingAppender" class="org.apache.log4j.RollingFileAppender">

        <!-- 日志文件全路径名 -->

        <param name="File" value="/data/applogs/RollingFileAppender.log" />

        <!--是否在已存在的文件追加写:默认时true,若为false则每次启动都会删除并重新新建文件-->

        <param name="Append" value="true" />

        <!-- 保存备份日志的最大个数,默认值是:1  -->

        <param name="MaxBackupIndex" value="10" />

        <!-- 设置当日志文件达到此阈值的时候自动回滚,单位可以是KB,MB,GB,默认单位是KB,默认值是:10MB -->

        <param name="MaxFileSize" value="10KB" />

        <!-- 设置日志输出的样式 -->`

        <layout class="org.apache.log4j.PatternLayout">

            <!-- 日志输出格式 -->

            <param name="ConversionPattern" value="[%d{yyyy-MM-dd HH:mm:ss:SSS}] [%-5p] [method:%l]%n%m%n%n" />

        </layout>

    </appender>

 

 

    <!-- 日志输出到文件,可以配置多久产生一个新的日志信息文件 -->

    <appender name="dailyRollingAppender" class="org.apache.log4j.DailyRollingFileAppender">

        <!-- 文件文件全路径名 -->

        <param name="File" value="/data/applogs/own/dailyRollingAppender.log"/>

        <param name="Append" value="true" />

        <!-- 设置日志备份频率,默认:为每天一个日志文件 -->

        <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />

 

        <!--每分钟一个备份-->

        <!--<param name="DatePattern" value="'.'yyyy-MM-dd-HH-mm'.log'" />-->

        <layout class="org.apache.log4j.PatternLayout">

            <param name="ConversionPattern" value="[%p][%d{HH:mm:ss SSS}][%c]-[%m]%n"/>

        </layout>

    </appender>

 

 

 

    <!--

        1. 指定logger的设置,additivity是否遵循缺省的继承机制

        2. 当additivity="false"时,root中的配置就失灵了,不遵循缺省的继承机制

        3. 代码中使用Logger.getLogger("logTest")获得此输出器,且不会使用根输出器

    -->

    <logger name="logTest" additivity="false">

        <level value ="INFO"/>

        <appender-ref ref="dailyRollingAppender"/>

    </logger>

 

 

    <!-- 根logger的设置,若代码中未找到指定的logger,则会根据继承机制,使用根logger-->

    <root>

        <appender-ref ref="console"/>

        <appender-ref ref="fileAppender"/>

        <appender-ref ref="rollingAppender"/>

        <appender-ref ref="dailyRollingAppender"/>

    </root>

 

</log4j:configuration>

测试代码:

package com.cas.test;

 

 

import org.apache.log4j.Logger;

import org.slf4j.LoggerFactory;

 

public class TestMain {

private static final Logger logger = Logger.getLogger(TestMain.class);

 

private static final org.slf4j.Logger log = LoggerFactory.getLogger(TestMain.class);

 

public static void main(String[] args) {

//PropertyConfigurator.configure("D:\\Program Files\\java\\Tomcat\\apache-tomcat-6.0.36.15\\webapps\\qymh_cas\\WEB-INF\\classes\\log4j.properties");

 

logger.info("DSFSDFSDF");

 

log.info("SSS");

log.error("Email send error", "PPPPPPPP");

}

}

@Component

public class LogTest {

    Logger logger = Logger.getLogger("logTest1");

 

    @PostConstruct

    public void test(){

        for (int i=0; i<1000; i++) {

            logger.info(i + "----Log.Info----");

            logger.info(i + "----Log.Info----");

            logger.info(i + "----Log.Info----");

        }

    }

}

测试结果:

控制台日志输出展示: 

 

 

 

日志输出文件:

 

 

 

示例二:

 

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

<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

 

<!-- Appenders 日志信息输出目的地 -->

 

<!-- ConsoleAppender -->

<!-- 每个ConsoleAppender都有一个target,表示它的输出目的地。 -->

<!-- 它可以是System.out,标准输出设备(缓冲显示屏) -->

<!-- 或者是System.err,标准错误设备(不缓冲显示屏) -->

<appender name="console" class="org.apache.log4j.ConsoleAppender">

<param name="Target" value="System.out" />

<layout class="org.apache.log4j.PatternLayout">

<param name="ConversionPattern" value="%d %-5p: %c - %m%n" />

</layout>

</appender>

 

<!-- RollingFileAppender 回滚文件 -->

<!-- Append true,默认每次启动系统,日志继续输出到原来的文件,而不是清空了再来 -->

<!-- MaxFileSize 后缀可以是KB, MB 或者是 GB. 在日志文件到达该大小时,将会自动滚动,即将原来的内容移到mylog.log.1文件 -->

<!-- MaxBackupIndex 最多20个 -->

<!-- PatternLayout 控制日志输出的格式化,参考上面的那些符合说明,自己怼自己想要的格式。 -->

<!-- filter 级别范围过滤器 -->

<!-- levelMin levelMax 范围 -->

<appender name="StreamOperateFile" class="org.apache.log4j.RollingFileAppender">

<param name="File" value="f:/ezLog/streamOperate.log" />

<param name="Append" value="true"/>

<param name="MaxFileSize" value="10MB"/>

<param name="MaxBackupIndex" value="20"/>  

<layout class="org.apache.log4j.PatternLayout">

<param name="ConversionPattern" value="%m%n" />

</layout>

<filter class="org.apache.log4j.varia.LevelRangeFilter">

<param name="levelMin" value="INFO" />

<param name="levelMax" value="INFO" />

<param name="AcceptOnMatch" value="true" />

</filter>  

</appender>

 

<!-- 同上 回滚文件,有2个的原因就是演示,把不同的日志输出到不同的文件 -->

<appender name="File" class="org.apache.log4j.RollingFileAppender">

<param name="File" value="f:/ezLog/production.log" />

<param name="Append" value="true"/>

<param name="MaxFileSize" value="10MB"/>

<param name="MaxBackupIndex" value="20"/>  

<layout class="org.apache.log4j.PatternLayout">

<param name="ConversionPattern" value="%d %-5p: %c - %m%n" />

</layout>

</appender>

 

<!-- 下面这些就是根据 这些路径来控制对应包下的文件的日志输出级别,基本上都是报错了,才输出日志-->

<logger name="org.springframework.core">

<level value="error" />

</logger>

 

<logger name="org.springframework.beans">

<level value="error" />

</logger>

 

<logger name="org.springframework.context">

<level value="error" />

</logger>

 

<logger name="org.springframework.http">

<level value="error" />

</logger>

 

<logger name="org.springframework.web">

<level value="error" />

</logger>

 

<logger name="org.elasticsearch.client.transport">

<level value="debug" />

</logger>

 

<logger name="org.springframework.data.mongodb">

<level value="error" />

</logger>

 

<!-- 这个就是自定义的一个logger -->

<!-- 输出级别是info级别及以上的日志,不要怕,StreamOperateFile已经过滤,只输出info级别的日志 -->

<!-- additivity 这个默认是true,即继承父类 root logger -->

<!-- 也就是说,你的这个日志也会在root的logger里面输出的,我这里配置false,就是不继承,各走各的。 -->

<!-- appender-ref 也就是说这个logger的输出目的地是哪里,ref就是关联到上面声明的一个file,一个console -->

<logger name="StreamOperateFile" additivity="false">

<level value="info" />

<appender-ref ref="StreamOperateFile" />

<appender-ref ref="console" />

</logger>

 

<!-- 传说中的根logger -->

<!-- 输出级别是info级别及以上的日志,下面的ref关联的两个appender没有filter设置,所以,info及以上的日志都是会输出到这2个appender的 -->

<root>

<priority value="info" />

<appender-ref ref="console" />

<appender-ref ref="File" />

</root>

 

</log4j:configuration>

测试代码:

private static final Logger STREAM_OPERATE_LOG = LoggerFactory.getLogger("StreamOperateFile");

STREAM_OPERATE_LOG.info("你要输出的日志信息");

getLogger("StreamOperateFile")的参数和你配置的那个要对应。

最后,真的在配置的地方生成了2个不同的日志文件,而且内容是不重叠的,各自是各自的。

 

分享到:
评论

相关推荐

    log4j.jar及log4j.xml

    以上内容详细介绍了Log4j.jar的核心组件和log4j.xml配置文件的作用,它们共同构成了Log4j日志框架的基础。通过合理的配置和使用,Log4j能够为开发者提供强大且灵活的日志管理能力,帮助他们更好地监控和维护Java应用...

    log4j.properties配置详解 使用教程

    ### log4j.properties配置详解与使用教程 #### 一、log4j简介 log4j是Apache的一个开源项目,用于实现日志功能。它提供了一种简单的方式来管理和配置应用程序的日志输出,支持多种输出目的地(如控制台、文件等)...

    Log4j.properties配置详解

    ### Log4j.properties配置详解 #### 一、Log4j简介 Log4j是一个非常流行的Java日志框架,它能够帮助开发者轻松管理日志记录。Log4j的主要优点包括灵活性高、性能好以及易于配置。它由三个核心组件组成:记录器...

    SSM整合中的Log4j日志的配置详情

    Log4j 在 SSM 整合中的配置详解 Log4j 是一个功能强大且广泛使用的日志记录工具,特别是在 SSM(Spring、Spring MVC、Mybatis)整合项目中,合理地配置 Log4j 对项目的日志记录和输出至关重要。本文将详细介绍 SSM...

    log4j.properties配置详解.doc

    在实际应用中,通过修改`log4j.properties`或`log4j.xml`文件,可以轻松调整日志配置,满足不同环境和需求。例如,开发阶段可能需要DEBUG级别的详细日志,而生产环境中可能只需要ERROR级别的日志,这时只需更改配置...

    log4j.xml文件的配置文.pdf

    ### 关于Log4j.xml配置文件的理解与应用 #### 一、引言 在Java开发领域,日志记录是至关重要的一个环节。它不仅能够帮助开发者更好地了解程序运行时的状态,还能在出现故障时快速定位问题所在。Log4j作为一款优秀...

    Log4.properties配置详解

    ### Log4j配置详解 #### 一、Log4j简介 Log4j 是一款非常流行的 Java 日志框架,由 Apache 软件基金会所提供。它能够帮助开发者在应用程序中记录日志信息,使得应用程序能够在运行时更加透明地展示其内部状态。Log...

    log4j2-所需jar包+配置详解(详细)

     log4j 2.x版本不再支持像1.x中的.properties后缀的文件配置方式,2.x版本配置文件后缀名只能为".xml",".json"或者".jsn".  系统选择配置文件的优先级(从先到后)如下:  (1).classpath下的名为log4j2-test.json...

    log4j.properties详解与例子

    Log4j支持两种配置格式:XML和Properties(键值对)。本篇主要关注Properties格式。 1. 配置根Logger: 根Logger是所有其他Logger的默认父Logger,它定义了日志记录的全局行为。`log4j.rootLogger`的语法如下: `...

    log4j配置文件说明(完整版)

    Log4j 配置文件说明 Log4j 是一种流行的日志记录工具,用于记录和管理应用程序中的日志信息。配置文件是 Log4j 的核心组件之一,通过配置文件可以控制日志记录的级别、输出目的地和格式。在本文中,我们将详细介绍 ...

    SpringBoot框架配置log4j和log4j2的配置代码

    2. **配置文件**:创建`log4j.properties`或`log4j.xml`文件,定义日志级别和输出目的地。例如: ```properties # log4j.properties 示例 log4j.rootLogger=DEBUG, stdout, file log4j.appender.stdout=org.apache....

    applicationContext.xml 详细配置

    ApplicationContext.xml 配置详解 ApplicationContext.xml 是 Spring 框架中用于配置应用程序的核心配置文件。通过该文件,可以定义 Bean、数据源、Session 工厂、 Hibernate 配置等相关信息,从而实现应用程序的...

    log4j常用配置详解

    ### log4j常用配置详解 ### #### 一、log4j.properties 配置解析 #### 在Java开发领域中,log4j是一款非常流行的日志框架,它提供了丰富的配置选项来满足不同场景下的日志记录需求。本文将详细介绍两种常见的log4j...

    log4j和ibatis配置文档

    《log4j与iBatis配置详解》 在软件开发中,日志管理和数据库操作是两个至关重要的环节。Log4j作为Java世界里最流行的日志框架之一,它提供了强大的日志记录功能,帮助开发者追踪应用程序运行过程中的信息、警告、...

    log4j中配置日志文件相对路径方法(PDF)

    ### Log4j中配置日志文件相对路径方法详解 #### 概述 在软件开发过程中,日志记录是一项重要的功能,它有助于开发者调试程序、监控应用程序的运行状态以及追踪问题。`Log4j`作为一款优秀的日志管理工具,被广泛应用...

    log4j.1.2.7

    Log4j的核心配置文件是`log4j.properties`或`log4j.xml`。在1.2.7版本中,你可以通过配置文件指定日志的输出级别、输出目标和格式。例如: ```properties # log4j.properties 示例 log4j.rootLogger=INFO, stdout, ...

    新版本与旧版本log4j.jar包下载,附使用说明----.zip

    3. **IDEA与log4j**: IntelliJ IDEA(简称IDEA)是一款流行的Java集成开发环境,它支持将log4j集成到项目中,通过配置pom.xml或build.gradle文件添加依赖,或者手动将log4j.jar添加到项目的类路径下,以便在IDEA中...

    log4j使用笔记

    #### 四、log4j 配置详解 1. **配置文件**: - `log4j.properties` 或 `log4j.xml` 文件用于定义 log4j 的配置规则。 - 配置文件通常放置在项目的根目录或者类路径下。 - 如果未指定配置文件的位置,则 log4j 会...

    log4j.zip和log4j.jar日志文档的处理

    1. **配置文件详解**:了解如何在`log4j.properties`或`log4j.xml`中设置日志级别、指定Appender和Layout,以及应用过滤器。 2. **使用Logger**:学习如何在代码中创建和使用Logger对象,以及如何设置日志级别。 3...

Global site tag (gtag.js) - Google Analytics