Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 387|回复: 0

[jsp学习]log4j的xml配置:分级打印日志和打印到指定文件中

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-2 06:45:44 | 显示全部楼层 |阅读模式
    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
    <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
            <!-- appender 部分是可用的日志输出方式定义,可以定义多个 -->
            <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
                    <layout class="org.apache.log4j.PatternLayout">
                            <param name="ConversionPattern" value="%l %d{ISO8601}-- %p -- %m%n"/>
                    </layout>
            </appender>
            <appender name="DEBUG" class="org.apache.log4j.RollingFileAppender">
                    <param name="File" value="e:/logs/debug.log"/>
                    <param name="Append" value="true"/>
                    <param name="MaxFileSize" value="10000KB"/>
                    <param name="MaxBackupIndex" value="50"/>
                    <layout class="org.apache.log4j.PatternLayout">
                            <param name="ConversionPattern" value="%l %d{ISO8601}-- %p -- %m%n"/>
                    </layout>
                    <filter class="org.apache.log4j.varia.LevelRangeFilter">
                    <param name="LevelMin" value="DEBUG" />
                    <param name="LevelMax" value="DEBUG" />
                    </filter>
            </appender>
            <appender name="INFO" class="org.apache.log4j.RollingFileAppender">
            <param name="File" value="e:/logs/info.log"/>
            <param name="Append" value="true"/>
            <param name="MaxFileSize" value="10000KB"/>
            <param name="MaxBackupIndex" value="50"/>
            <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%l %d{ISO8601}-- %p -- %m%n"/>
            </layout>
            <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="INFO" />
            <param name="LevelMax" value="INFO" />
            </filter>
            </appender>
            <appender name="WARN" class="org.apache.log4j.RollingFileAppender">
            <param name="File" value="e:/logs/warn.log"/>
            <param name="Append" value="true"/>
            <param name="MaxFileSize" value="10000KB"/>
            <param name="MaxBackupIndex" value="50"/>
            <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%l %d{ISO8601}-- %p -- %m%n"/>
            </layout>
            <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="WARN" />
            <param name="LevelMax" value="WARN" />
            </filter>
            </appender>
            <appender name="ERROR" class="org.apache.log4j.RollingFileAppender">
            <param name="File" value="e:/logs/error.log"/>
            <param name="Append" value="true"/>
            <param name="MaxFileSize" value="10000KB"/>
            <param name="MaxBackupIndex" value="50"/>
            <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%l %d{ISO8601}-- %p -- %m%n"/>
            </layout>
            <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="ERROR" />
            <param name="LevelMax" value="ERROR" />
            </filter>
            </appender>
           
           
            <appender name="WATCHTASK" class="org.apache.log4j.RollingFileAppender">
            <param name="File" value="e:/logs/watchtask.log"/>
            <param name="Append" value="true"/>
            <param name="MaxFileSize" value="10000KB"/>
            <param name="MaxBackupIndex" value="50"/>
            <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%l %d{ISO8601}-- %p -- %m%n"/>
            </layout>
            <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="INFO" />
            <param name="LevelMax" value="INFO" />
            </filter>
            </appender>
           
            <!--  category 部分定义了特定包或者类的输出级别和方式,可以有多个 -->
            <category name="org.apache">
               <priority value="warn"/>
               <appender-ref ref="WARN"/>
            </category>
           
        <!--  打印日志到固定的文件中WATCHTASK 选择自定义的日志级别设置 -->
        <category name="com.test.task.WatchTimerTask">
               <priority value="info"/>
               <appender-ref ref="WATCHTASK"/>
            </category>
       
            <!--  root部分定义了log4j的默认输出级别和方式 -->
            <root>
                    <priority value="warn"/>
                    <appender-ref ref="INFO"/>
                    <appender-ref ref="WARN"/>
                    <appender-ref ref="ERROR"/>
                    <appender-ref ref="STDOUT"/>
                   
            </root>
    </log4j:configuration>

    (1). 输出方式appender一般有5种:[/code]
         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 输出日志时间其格式为 %d{yyyy-MM-dd HH:mm:ss,SSS},可指定格式 如 %d{HH:mm:ss}
    %l? 输出日志事件发生位置,包括类目名、发生线程,在代码中的行数
    %n 换行符
    %m 输出代码指定信息,如info(“message”),输出message
    %p 输出优先级,即 FATAL ,ERROR 等
    %r 输出从启动到显示该log信息所耗费的毫秒数
    %t 输出产生该日志事件的线程名
                              [/code]
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-26 22:08 , Processed in 0.369505 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表