zoukankan      html  css  js  c++  java
  • log4j.xml如何配置

    Xml代码

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

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

    <appender name="myConsole" class="org.apache.log4j.ConsoleAppender">
    <layout class="org.apache.log4j.PatternLayout">
    <param name="ConversionPattern"
    value="[%d{dd HH:mm:ss,SSS\} %-5p] [%t] %c{2\} - %m%n" />
    </layout>
    <!--过滤器设置输出的级别-->
    <filter class="org.apache.log4j.varia.LevelRangeFilter">
    <param name="levelMin" value="debug" />
    <param name="levelMax" value="warn" />
    <param name="AcceptOnMatch" value="true" />
    </filter>
    </appender>

    <appender name="myFile" class="org.apache.log4j.RollingFileAppender">
    <param name="File" value="D:/output.log" /><!-- 设置日志输出文件名 -->
    <!-- 设置是否在重新启动服务时,在原有日志的基础添加新日志 -->
    <param name="Append" value="true" />
    <param name="MaxBackupIndex" value="10" />
    <layout class="org.apache.log4j.PatternLayout">
    <param name="ConversionPattern" value="%p (%c:%L)- %m%n" />
    </layout>
    </appender>

    <appender name="activexAppender" class="org.apache.log4j.DailyRollingFileAppender">
    <param name="File" value="E:/activex.log" />
    <param name="DatePattern" value="'.'yyyy-MM-dd'.log'" />
    <layout class="org.apache.log4j.PatternLayout">
    <param name="ConversionPattern"
    value="[%d{MMdd HH:mm:ss SSS\} %-5p] [%t] %c{3\} - %m%n" />
    </layout>
    </appender>

    <!-- 指定logger的设置,additivity指示是否遵循缺省的继承机制-->
    <logger name="com.runway.bssp.activeXdemo" additivity="false">
    <priority value ="info"/>
    <appender-ref ref="activexAppender" />
    </logger>

    <!-- 根logger的设置-->
    <root>
    <priority value ="debug"/>
    <appender-ref ref="myConsole"/>
    <appender-ref ref="myFile"/>
    </root>
    </log4j:configuration>



    (1). 输出方式appender一般有5种:

    org.apache.log4j.RollingFileAppender(滚动文件,自动记录最新日志)
    org.apache.log4j.ConsoleAppender (控制台)
    org.apache.log4j.FileAppender (文件)
    org.apache.log4j.DailyRollingFileAppender (每天产生一个日志文件)
    org.apache.log4j.WriterAppender (将日志信息以流格式发送到任意指定的地方)



    (2). 日记记录的优先级priority,优先级由高到低分为
    OFF ,FATAL ,ERROR ,WARN ,INFO ,DEBUG ,ALL。
    Log4j建议只使用FATAL ,ERROR ,WARN ,INFO ,DEBUG这五个级别。



    (3). 格式说明layout中的参数都以%开始,后面不同的参数代表不同的格式化信息(参数按字母表顺序列出):
    %c 输出所属类的全名,可在修改为 %d{Num} ,Num类名输出的维(如:"org.apache.elathen.ClassName",%C{2}将输出elathen.ClassName)
    %d 输出日志时间其格式为 %d{yyyy-MM-dd HH:mm:ss,SSS},可指定格式 如 %d{HH:mm:ss}
    %l 输出日志事件发生位置,包括类目名、发生线程,在代码中的行数
    %n 换行符
    %m 输出代码指定信息,如info(“message”),输出message
    %p 输出优先级,即 FATAL ,ERROR 等
    %r 输出从启动到显示该log信息所耗费的毫秒数
    %t 输出产生该日志事件的线程名


    xml declaration and DTD

    xml配置文件的头部包括两个部分:xml声明和DTD声明。头部的格式如下:

    <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">


    log4j:configuration (root element)

    xmlns:log4j [#FIXED attribute] : 定义log4j的名字空间,取定值"http://jakarta.apache.org/log4j/"
    appender [* child] : 一个appender子元素定义一个日志输出目的地
    logger [* child] : 一个logger子元素定义一个日志写出器
    root [? child] : root子元素定义了root logger


    appender

    appender元素定义一个日志输出目的地。

    name [#REQUIRED attribute] : 定义appender的名字,以便被后文引用
    class [#REQUIRED attribute] : 定义appender对象所属的类的全名
    param [* child] : 创建appender对象时传递给类构造方法的参数
    layout [? child] : 该appender使用的layout对象


    layout

    layout元素定义与某一个appender相联系的日志格式化器。

    class [#REQUIRED attribute] : 定义layout对象所属的类的全名
    param [* child] : 创建layout对象时传递给类构造方法的参数


    logger

    logger元素定义一个日志输出器。

    name [#REQUIRED attribute] : 定义logger的名字,以便被后文引用
    additivity [#ENUM attribute] : 取值为"true"(默认)或者"false",是否继承父logger的属性
    level [? child] : 定义该logger的日志级别
    appender-ref [* child] : 定义该logger的输出目的地


    root

    root元素定义根日志输出器root logger。

    param [* child] : 创建root logger对象时传递给类构造方法的参数
    level [? child] : 定义root logger的日志级别
    appender-ref [* child] : 定义root logger的输出目的地


    level

    level元素定义logger对象的日志级别。

    class [#IMPLIED attribute] : 定义level对象所属的类,默认情况下是"org.apache.log4j.Level类
    value [#REQUIRED attribute] : 为level对象赋值。可能的取值从小到大依次为"all"、"debug"、"info"、"warn"、"error"、"fatal"和"off"。当值为"off"时表示没有任何日志信息被输出
    param [* child] : 创建level对象时传递给类构造方法的参数


    appender-ref

    appender-ref元素引用一个appender元素的名字,为logger对象增加一个appender。

    ref [#REQUIRED attribute] : 一个appender元素的名字的引用
    appender-ref元素没有子元素


    param

    param元素在创建对象时为类的构造方法提供参数。它可以成为appender、layout、filter、errorHandler、level、categoryFactory和root等元素的子元素。

    name and value [#REQUIRED attributes] : 提供参数的一组名值对
    param元素没有子元素
    在xml文件中配置appender和layout

    创建不同的Appender对象或者不同的Layout对象要调用不同的构造方法。可以使用param子元素来设定不同的参数值。
    创建ConsoleAppender对象

    ConsoleAppender的构造方法不接受其它的参数。

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

    创建FileAppender对象

    可以为FileAppender类的构造方法传递两个参数:File表示日志文件名;Append表示如文件已存在,是否把日志追加到文件尾部,可能取值为"true"和"false"(默认)。

    ... ... ... ... <appender name="file.log" class="org.apache.log4j.FileAppender"> <param name="File" value="/tmp/log.txt" /> <param name="Append" value="false" /> <layout ... > ... ... </layout> </appender> ... ... ... ...

    创建RollingFileAppender对象

    除了File和Append以外,还可以为RollingFileAppender类的构造方法传递两个参数:MaxBackupIndex备份日志文件的个数(默认是1个);MaxFileSize表示日志文件允许的最大字节数(默认是10M)。

    ... ... ... ... <appender name="rollingFile.log" class="org.apache.log4j.RollingFileAppender"> <param name="File" value="/tmp/rollingLog.txt" /> <param name="Append" value="false" /> <param name="MaxBackupIndex" value="2" /> <param name="MaxFileSize" value="1024" /> <layout ... > ... ... </layout> </appender> ... ... ... ...

    创建PatternLayout对象

    可以为PatternLayout类的构造方法传递参数ConversionPattern。

    ... ... ... ... <layout class="org.apache.log4j.PatternLayout> <param name="Conversion" value="%d [%t] %p - %m%n" /> </layout> ... ... ... ...

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


    The Apache Log4J project offers a framework for logging aspects in Java software components. Today Apache Log4j is a defacto standard to realize priority/level based log messages in Java and .Net environments. The developer has to understand the following Log4J elements and classes to use this logging framework.
    Appenders - defines handlers how to persist log entries, for example FileAppenders, SMTPAppenders, JDBCAppenders and so on
    Level/Priority - diffentent levels of logging entries, e.g. INFO, DEBUG, ERROR, TRACE, ...
    Logger - defines relations between packages and appenders, e.g. all classes of org.developers.* should be save per special appender
    ...

    You can configure your logging parameters per log4j.xml file, which should be saved at the root directory of your jar or source folder. The following log4j.xml file contains an basic configuration:
    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd" > <log4j:configuration> <!-- APPENDERS LIST --> <!-- show log entries on console --> <appender name="consoleAppender" class="org.apache.log4j.ConsoleAppender"> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d{ABSOLUTE} %5p %c{1}:%L - %m%n"/> </layout> </appender> <!-- log all logs to a separate log file every day --> <appender name="orgDevelopersLogFileAppender" class="org.apache.log4j.DailyRollingFileAppender"> <param name="file" value="org-file.log" /> <param name="datePattern" value="'.'yyyy-MM-dd" /> <param name="append" value="true" /> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d [%t] %-5p %C{6} (%F:%L) - %m%n"/> </layout> </appender> <!-- log all logs to a separate log file every day --> <appender name="comDevelopersLogFileAppender" class="org.apache.log4j.DailyRollingFileAppender"> <param name="file" value="file.log" /> <param name="datePattern" value="'.'yyyy-MM-dd" /> <param name="append" value="true" /> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d [%t] %-5p %C{6} (%F:%L) - %m%n"/> </layout> </appender> <!-- send all error logs to my email address --> <appender name="mailAppender" class="org.apache.log4j.net.SMTPAppender"> <param name="SMTPHost" value="localhost" /> <param name="From" value="info@developers-blog.org" /> <param name="To" value="rafael@developers-blog.org" /> <param name="Subject" value="[BLOG ERROR LOG] ErrorList" /> <!-- if your buffer contains 50 mails, an email should be sent --> <param name="BufferSize" value="50" /> <!-- send only errors per email --> <param name="threshold" value="error" /> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="%d{ABSOLUTE} %5p %c{1}:%L - %m%n" /> </layout> </appender> <!-- LOGGER LIST --> <!-- log all classes in org.developers package --> <logger name="org.developers"> <!-- level info logs --> <level value="INFO" /> <appender-ref ref="orgDevelopersLogFileAppender"/> </logger> <logger name="com.developers"> <!-- level debug logs --> <level value="DEBUG" /> <appender-ref ref="mailAppender"/> </logger> <root> <priority value="debug"></priority> <!-- log all log entries on console --> <appender-ref ref="consoleAppender"/> <!-- push all error logs to mailAppender --> <appender-ref ref="mailAppender"/> </root> </log4j:configuration>
    Regards
    Rafael Sobek

  • 相关阅读:
    restful
    spark深入:配置文件与日志
    Spark多种运行模式
    Spark 序列化问题
    [转]关于PreparedStatement.addBatch()方法
    scala helloworld
    java IO操作:FileInputStream,FileOutputStream,FileReader,FileWriter实例
    replace与replaceAll的区别
    String,StringBuffer与StringBuilder
    hive 空值、NULL判断
  • 原文地址:https://www.cnblogs.com/suifengbingzhu/p/2666840.html
Copyright © 2011-2022 走看看