<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'>

<!-- ========================== 自定义输出格式说明================================ -->  <!-- %p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL -->  <!-- %r 输出自应用启动到输出该log信息耗费的毫秒数 -->  <!-- %m 日志内容 -->  <!-- %c 输出所属的类目,通常就是所在类的全名 -->  <!-- %t 输出产生该日志事件的线程名 -->  <!-- %n 输出一个回车换行符,Windows平台为“/r/n”,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提供的appender有以下几种: -->  <!-- org.apache.log4j.ConsoleAppender(控制台), -->  <!-- org.apache.log4j.FileAppender(文件), -->  <!-- org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), -->  <!-- org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件), -->  <!-- org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) -->

<!-- ========================== 布局方式说明================================ -->  <!-- Log4j提供的appender有以下几种: -->  <!-- org.apache.log4j.HTMLLayout(以HTML表格形式布局), -->  <!--org.apache.log4j.PatternLayout(可以灵活地指定布局模式), -->  <!--org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串), -->  <!--org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息) -->

<!-- 关于日志level. -->  <!-- 共有8个级别,按照从低到高为:All < Trace < Debug < Info < Warn < Error < Fatal <   OFF. -->  <!-- All:最低等级的,用于打开所有日志记录. -->  <!-- Trace:是追踪,就是程序推进以下,你就可以写个trace输出,所以trace应该会特别多,不过没关系,我们可以设置最低日志级别不让他输出. -->  <!-- Debug:指出细粒度信息事件对调试应用程序是非常有帮助的. -->  <!-- Info:消息在粗粒度级别上突出强调应用程序的运行过程. -->  <!-- Warn:输出警告及warn以下级别的日志. -->  <!-- Error:输出错误信息日志. -->  <!-- Fatal:输出每个严重的错误事件将会导致应用程序的退出的日志. -->  <!-- OFF:最高等级的,用于关闭所有日志记录. -->  <!-- ========================================================================== -->

<appender name="CONSOLE" class="org.apache.log4j.ConsoleAppender">   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>

<!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="OFF" />    <param name="LevelMin" value="INFO" />   </filter>  </appender>

<!-- org.apache.log4j.FileAppender(文件), 可以指定文件大小和文件数 这里没用这种方式 -->  <appender name="RollingDEBUG" class="org.apache.log4j.RollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/sfpt.log" />   <!-- 文件到达这个大小,就新建个文件 -->   <param name="MaxFileSize" value="500KB" />   <!-- 文件到达这个个数,就开始滚存之前的记录 -->   <param name="MaxBackupIndex" value="2" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss} [%p] 线程名:%t 源:%l 自应用启动到输出该log信息毫秒数:%r 内容:%n%m%n%n" />   </layout>   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMin" value="DEBUG" />    <param name="LevelMax" value="DEBUG" />   </filter>  </appender>

<appender name="All" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/all/all.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss} [%p] 线程名:%t 源:%l 自应用启动到输出该log信息毫秒数:%r 内容:%n%m%n%n" />   </layout> <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="OFF" />    <param name="LevelMin" value="Info" />   </filter>  </appender>

<appender name="Trace" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/trace/trace.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>   <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="Trace" />    <param name="LevelMin" value="Trace" />   </filter>  </appender>

<appender name="Debug" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/debug/debug.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>   <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="Debug" />    <param name="LevelMin" value="Debug" />   </filter>  </appender>

<appender name="Info" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/info/info.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>   <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="Info" />    <param name="LevelMin" value="Info" />   </filter>  </appender>

<appender name="Warn" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/warn/warn.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>   <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="Warn" />    <param name="LevelMin" value="Warn" />   </filter>  </appender>

<appender name="Error" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/error/error.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>   <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="Error" />    <param name="LevelMin" value="Error" />   </filter>  </appender>

<appender name="Fatal" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/fatal/fatal.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>   <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="Fatal" />    <param name="LevelMin" value="Fatal" />   </filter>  </appender>

<appender name="OFF" class="org.apache.log4j.DailyRollingFileAppender">   <param name="Encoding" value="UTF-8" />   <param name="File" value="/home/log/sfpt/off/off.log" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>   <!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="OFF" />    <param name="LevelMin" value="OFF" />   </filter>  </appender>

<appender name="Database" class="org.apache.log4j.jdbc.JDBCAppender">   <param name="Encoding" value="UTF-8" />   <param name="URL" value="jdbc:oracle:thin:@192.168.0.59:1521:oanet" />   <param name="driver" value="oracle.jdbc.driver.OracleDriver" />   <param name="user" value="hdczoa" />   <param name="password" value="system" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="INSERT INTO hdczoa.LOG4J(stamp,thread, info_level,class,message) VALUES ('%d', '%t', '%p', '%c', %m)" />   </layout>

<!--限制输出级别 -->   <filter class="org.apache.log4j.varia.LevelRangeFilter">    <param name="LevelMax" value="OFF" />    <param name="LevelMin" value="OFF" />   </filter>  </appender>

<!-- 发邮件(只有ERROR时才会发送!) -->  <appender name="Mail" class="org.apache.log4j.net.SMTPAppender">   <param name="Encoding" value="UTF-8" />   <param name="Threshold" value="OFF" />   <param name="SMTPDebug" value="false" />   <param name="SMTPProtocol" value="smtp" />   <!-- 日志的错误级别 <param name="threshold" value="fatal"/> -->   <!-- 缓存文件大小,日志达到512K时发送Email -->   <param name="BufferSize" value="512" /><!-- 单位K -->   <param name="From" value="cdjs@ywymsy.cn" />   <param name="To" value="543013306@qq.com,543013306@qq.com" />   <param name="SMTPHost" value="smtp.ywymsy.cn" />   <param name="SMTPPort" value="25" />   <param name="Subject" value="sfpt 程序抛异常了" />   <param name="SMTPUsername" value="cdjs@ywymsy.cn" />   <param name="SMTPPassword" value="20110322_cdjs" />   <layout class="org.apache.log4j.PatternLayout">    <param name="ConversionPattern"     value="sfpt %-d{yyyy-MM-dd HH:mm:ss}  [%p]  线程名:%t  源:%l  自应用启动到输出该log信息毫秒数:%r  内容:%n%m%n%n" />   </layout>  </appender>

<!-- priority value="All" 用于定义输出什么级别以上的日志 -->  <root>   <priority value="All" />   <appender-ref ref="CONSOLE" />   <appender-ref ref="All" />   <appender-ref ref="Trace" />   <appender-ref ref="Debug" />   <appender-ref ref="Info" />   <appender-ref ref="Warn" />   <appender-ref ref="Error" />   <appender-ref ref="Fatal" />   <appender-ref ref="OFF" />   <!-- <appender-ref ref="datebase" /> -->   <!-- <appender-ref ref="Mail" /> -->  </root> </log4j:configuration>

/src/log4j.xml的更多相关文章

  1. 转载:log4j.properties log4j.xml 路径问题

    自动加载配置文件: (1)如果采用log4j输出日志,要对log4j加载配置文件的过程有所了解.log4j启动时,默认会寻找source folder下的log4j.xml配置文件,若没有,会寻找lo ...

  2. Log4j XML配置

    问题描述:     Log4j  XML配置 问题解决:     (1)编写log4j.xml配置文件 注:     如上的XML文件必须以log4j.xml文件命名,否则无法读取配置文件,同样的如果 ...

  3. log4j.xml 为什么要使用SLF4J而不是Log4J

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

  4. log4j.xml的实用例子

    大多数讲log4j配置的教程用的都是log4j.properties文件,我觉得xml或许更好一点,在这里我提供一个我已经用于生产环境的log4j.xml的例子,先上代码,然后再解释: <?xm ...

  5. log4j日志文件 log4j.xml log4j.properties配置

    1,导入log4j  jar包; 2,配置log4j.xml或log4j.properties文件; ------------------------------------------------- ...

  6. Log4j XML 配置

    Xml代码 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configurat ...

  7. log4j.xml配置文件

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

  8. log4j.xml配置示例

    这是log4j1.x版本讲解,log4j-1.2.16.jar    1. 一般的log4j.xml的两种配置方式: 1.Logger 完成日志信息的处理定义输出的层次和决定信息是否输出DEBUG&l ...

  9. (转)log4j(七)——log4j.xml简单配置样例说明

    背景:在公司中警察需要做技术支持,查看日志,而查看日志首先要自己清楚日志是如何生成的,所以有必要知道日志的前世今生! 转载出处:http://www.cnblogs.com/godtrue/p/644 ...

随机推荐

  1. Windows把内存变成快速虚拟硬盘

    笔记本电脑安装了8G内存,却装了个Win7 32位系统,结果只能识别2946MB内存,还有5GB多内存白白浪费了,那个闹心啊,别提多不爽,听说能把内存虚拟成硬盘使用,用它缓存系统临时文件,以及缓存网页 ...

  2. springboot打包

    springboot项目运行package命令,默认打出来的jar包只有几kb.想要打出可执行的jar包,加入插件: <build> <plugins> <plugin& ...

  3. api文档管理系统合集

    1.Swagger 2.Showdoc 3.EOAPI 4.阿里的RAP 5.postMan 6.docute: 无需编译的文档撰写工具 7.SmartWiki 接口文档在线管理系统 8.SosoAp ...

  4. 认识下java注解的实现原理

    1,什么是注解 注解也叫元数据,例如常见的@Override和@Deprecated,注解是JDK1.5版本开始引入的一个特性,用于对代码进行说明,可以对包.类.接口.字段.方法参数.局部变量等进行注 ...

  5. tomcat和eclipse-wtp的一些配置

    TOMCAT配置UTF-8 server.xml配置文件: <Connector port="8080" protocol="HTTP/1.1" conn ...

  6. ORA-00257: archiver error. Connect internal only, until freed【日志归档清理】

    select * from V$FLASH_RECOVERY_AREA_USAGE;  查看使用情况 用plsql登陆时提示“ORA-00257: archiver error. Connect in ...

  7. SAP系统中ASCS、ERS、PAS、AAS

    SAP系统中ASCS.ERS.PAS.AAS是什么: ASCS:ABAP Central services instance (Message server) PAS: Primary applica ...

  8. Centos配置jdk和tomcat环境

    centos java+tomcat环境配置 一.安装java环境 在CentOS7.2上安装jdk1.8(tar.gz安装包),并配置环境变量 jdk安装在/home/soft/jdk1.8.0-1 ...

  9. 精通Web Analytics 2.0 (12) 第十章:针对潜在的网站分析陷阱的最佳解决方案

    精通Web Analytics 2.0 : 用户中心科学与在线统计艺术 第十章:针对潜在的网站分析陷阱的最佳解决方案 是时候去处理网站分析中最棘手的一些问题了,然后获得属于你的黑带,这是成为分析忍者的 ...

  10. Dubbo的学习

    Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和 Spring框架无缝集成. Dubbo是一款高性能.轻量级的开源Java RP ...