spring log4j配置(log4j配置详解)

技术logger4j.properties和log4j.xml怎么配置这篇文章主要介绍“logger4j.properties和log4j.xml怎么配置”,在日常操作中,相信很多人在logger4j.propertie

这篇文章主要介绍” logger4j.properties和log4j.xml怎么配置”,在日常操作中,相信很多人在logger4j.properties和log4j.xml怎么配置问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答” logger4j.properties和log4j.xml怎么配置”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

log4j.xml的

?xmlversion=’1.0 ‘编码=’UTF-8 ‘?

!doctype log4j :配置系统’ log4j。’ dtd ‘

log4j : configurationxmlns : log4j=’ http://雅加达。阿帕奇。org/log4j/’

!-

*1.一个追加器子元素定义一个日志输出目的地

*2.一个记录器子元素定义一个日志写出器

!-卡特琳娜,出去-

appendername=’ console end ‘ class=’ org。阿帕奇。log4j。安慰者

布局类=’ org。阿帕奇。log4j。“模式布局”

param name=’ conversation pattern ‘ value=’ %-d { yyyy-MM-ddhh :MM 3360s }[% 5p][% t][% c { 1 }]-[% M]% M % n/

/布局

/appender

!-错误日志-

appendername=’ error append ‘ class=’ org。阿帕奇。log4j。’ dailyrollingfileappender ‘

参数名称=’文件’值=’ $ { webapp。root }/log/error/error。html ‘/

参数名=’追加’值=’真’/

参数名=’日期模式’值=’ yyyy-MM-DD-HH-MM ‘ .html”/

param name=’ MaxBackupIndex ‘ value=’ 10 ‘/

paramname=’MaxFileSizequ ‘

ot; value="4000000" />
        <param name="encoding" value="utf-8"/>
        <layout class="org.apache.log4j.HTMLLayout">
        </layout>
        <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="ERROR" />
            <param name="LevelMax" value="ERROR" />
        </filter>
    </appender>

    <!– biz –>
    <appender name="bizAppend" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/biz/biz.log" />
        <param name="Append" value="true" />
        <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
        <param name="MaxBackupIndex" value="10" />
        <param name="MaxFileSize" value="4096" />
        <param name="encoding" value="utf-8"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[date:%d{yyyy-MM-dd HH:mm:ss}] %m%n" />
        </layout>
        <filter class="com.raycloud.bizlogger.LoggerFilter">
            <param name="LevelMin" value="40050" />
            <param name="LevelMax" value="40050" />
        </filter>
    </appender>

    <!– 消费者消费的消息记录 –>
    <appender name="taskExcutorAppend" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/excutor/excutor.log" />
        <!– 每小时1个文件 –>
        <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
        <!– 最大文件的size,单位:Kb,Mb… –>
        <param name="MaxFileSize" value="4096" />
        <!– 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 –>
        <param name="Append" value="true"/>
        <!– 默认 MaxBackupIndex 为 1 –>
        <param name="MaxBackupIndex" value="10" />
        <param name="Encoding" value="utf-8"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
        </layout>
        <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="INFO" />
            <param name="LevelMax" value="WARN" />
        </filter>
    </appender>

    <!– ProcessHandler的日志 –>
    <appender name="processHandlerAppend" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/process/process.log" />
        <!– 每小时1个文件 –>
        <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
        <!– 最大文件的size,单位:Kb,Mb… –>
        <param name="MaxFileSize" value="4096" />
        <!– 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 –>
        <param name="Append" value="true"/>
        <!– 默认 MaxBackupIndex 为 1 –>
        <param name="MaxBackupIndex" value="10" />
        <param name="Encoding" value="utf-8"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
        </layout>
        <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="INFO" />
            <param name="LevelMax" value="WARN" />
        </filter>
    </appender>

    <!– command node js的日志 –>
    <appender name="nodejsAppend" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/command/nodejs.log" />
        <!– 每小时1个文件 –>
        <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
        <!– 最大文件的size,单位:Kb,Mb… –>
        <param name="MaxFileSize" value="4096" />
        <!– 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 –>
        <param name="Append" value="true"/>
        <!– 默认 MaxBackupIndex 为 1 –>
        <param name="MaxBackupIndex" value="10" />
        <param name="Encoding" value="utf-8"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
        </layout>
        <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="INFO" />
            <param name="LevelMax" value="WARN" />
        </filter>
    </appender>
    <!– command ffmpeg的日志 –>
    <appender name="ffmpegAppend" class="org.apache.log4j.DailyRollingFileAppender">
        <param name="File" value="${webapp.root}/logs/command/ffmpeg.log" />
        <!– 每小时1个文件 –>
        <param name="DatePattern" value="'.'yyyy-MM-dd-HH'.log'" />
        <!– 最大文件的size,单位:Kb,Mb… –>
        <param name="MaxFileSize" value="4096" />
        <!– 重启了服务器之后,是否在原有文件的后面追加?true(默认):追加;false:不追加 –>
        <param name="Append" value="true"/>
        <!– 默认 MaxBackupIndex 为 1 –>
        <param name="MaxBackupIndex" value="10" />
        <param name="Encoding" value="utf-8"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p] %m%n" />
        </layout>
        <filter class="org.apache.log4j.varia.LevelRangeFilter">
            <param name="LevelMin" value="INFO" />
            <param name="LevelMax" value="WARN" />
        </filter>
    </appender>

    <!–
        logger的作用:
        1.[name属性]:指定你定义Logger对象时候的name
        2. additivity : children-logger是否使用 rootLogger的配置,
           additivity在log4j默认为true。这解释了为什么有些时候,一个日志信息在屏幕上会有多次输出。
        3.还可以指定level(输出级别)、appender-ref(指定哪个append)
     –>
    <!– loggers –>
    <logger name="com.raycloud.picture.task.consumer.PictureVideoTaskExcutor" additivity="true">
        <!– 如果1个包想对应多个 Appender 就这样,对于每个Appender自定义的日志级别可以在Appender上加上filter –>
        <appender-ref ref="taskExcutorAppend" />
    </logger>
    <logger name="com.raycloud.picture.task.handle.impl.DefaultVideoProcessorHandleImpl" additivity="true">
        <appender-ref ref="processHandlerAppend" />
    </logger>
    <logger name="com.raycloud.picture.service.command.NodeJsCommandInvoke" additivity="true">
        <appender-ref ref="nodejsAppend" />
    </logger>
    <logger name="com.raycloud.picture.service.command.FfmpegCommandInvoke" additivity="true">
        <appender-ref ref="ffmpegAppend" />
    </logger>

    <!–
        root的作用(相当于全局的意思):
        1.[priority ]:指定默认的全局输出级别
        2.[appender-ref ]:指定一些默认的append(没有指出特殊包或者类,即那些没有指定<logger>元素的append)的输出;
    –>
<root>
<priority value="INFO" />
        <!– 将 logger 中 additivity=true 的日志或者没有指定<logger>的append输出到控制台 –>
        <appender-ref ref="consoleAppend" />
        <!– 将全局的 error 日志输出到error文件中 –>
<appender-ref ref="errorAppend" />
        <appender-ref ref="bizAppend" />
    </root>

</log4j:configuration>

  • log4j.xml在web.xml中的配置

    1. <!-- log4j -->
          <context-param>
              <param-name>log4jConfigLocation</param-name>
              <param-value>classpath:log4j-server.xml</param-value>
          </context-param>
          <context-param>
              <param-name>log4jRefreshInterval</param-name>
              <param-value>3000</param-value>
          </context-param>
          <!-- 先开启Log4J,再去启动spring等一些你需要的东西,有助于报错时日志的输出 -->
          <listener>
              <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
          </listener>
  • log4j.properties配置

    1. ####################################################
      # 将日志按照包分类输出的配置文件
      ####################################################
      
      #根针对所有的日志包
      log4j.rootLogger = debug , appendConsole
      #下面两个配置是指定包的特殊处理,针对两个指定的日志级别,如果不指定的话则使用父日志记录器(rootLogger)的,指定了就覆盖掉了父日志记录器的
      #设置dao包的日志配置
      log4j.logger.com.xun.log4j.dao = debug, appendDao
      #设置service包的日志配置
      log4j.logger.com.xun.log4j.service = info, appendService
      
      
      #控制台的配置
      log4j.appender.appendConsole = org.apache.log4j.ConsoleAppender
      #Threshold:设置此appender的日志级别,这里会覆盖全局的(rootLogger中)定义的日志级别
      log4j.appender.appendConsole.Threshold = error
      #设置日志输出编码方式为UTF-8,如果不指定,会以当前运行操作系统的编码方式记录
      log4j.appender.appendConsole.encoding = UTF-8
      log4j.appender.appendConsole.layout = org.apache.log4j.SimpleLayout
      
      #appendDao配置
      log4j.appender.appendDao = org.apache.log4j.FileAppender
      log4j.appender.appendDao.layout = org.apache.log4j.PatternLayout
      log4j.appender.appendDao.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:ss}]--[%t] [%p] -%l -%m%n%n
      log4j.appender.appendDao.Append = false
      log4j.appender.appendDao.File = e:/test/log4j/dao.txt
      
      #appendService
      log4j.appender.appendService = org.apache.log4j.FileAppender
      log4j.appender.appendService.layout = org.apache.log4j.PatternLayout
      log4j.appender.appendService.layout.ConversionPattern = [%d{yyyy-MM-dd HH:mm:ss}]--[%t] [%p] -%l -%m%n%n
      log4j.appender.appendService.Append = false
      log4j.appender.appendService.File = e:/test/log4j/service.txt
    2. //方式一:自动快速的使用Log4J缺省的环境
      //        BasicConfigurator.configure();
      
              //方式二:读取properties文件(自定义位置),但是注意这里文件的加载路径
      //        PropertyConfigurator.configure("E:/workspace-idea/study-demo/log4j-test/src/main/resources/log4j/log4j.properties");
      //        PropertyConfigurator.configure(HowUseLog4JDemo.class.getClassLoader().getResource("log4j/log4j.properties").getFile());
      
              //方式三:读取XML文件
      //        DOMConfigurator.configure("xxx");

    到此,关于“logger4j.properties和log4j.xml怎么配置”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

    内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/150540.html

    (0)

    相关推荐

    • 基于Arduino OpenCV的弹跳机器人是什么?

      技术基于Arduino+OpenCV的颠球机器人是怎样的本篇文章给大家分享的是有关基于Arduino+OpenCV的颠球机器人是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说

      攻略 2021年12月15日
    • Java反射有什么优点

      技术Java反射有什么优点这篇文章主要讲解了“Java反射有什么优点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java反射有什么优点”吧!在谈反射之前,先思考一个问题

      攻略 2021年11月30日
    • 泰山海拔高度,泰山的主峰到底有多高啊

      技术泰山海拔高度,泰山的主峰到底有多高啊泰山的主峰是玉皇顶泰山海拔高度,高度海拔1532.7米。玉皇顶,是泰山主峰之巅,因峰顶有玉皇庙而得名。玉皇顶旧称太平顶,又名天柱峰,始建年代无考,明成化年间重修。神龛上匾额题“柴望

      生活 2021年10月22日
    • DIV+CSS网页内容显示不完整诊断是这样的

      技术DIV+CSS网页内容显示不完整诊断是这样的DIV+CSS网页内容显示不完整诊断是这样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。本文和大家重点

      攻略 2021年11月11日
    • 树莓派如何定时通过摄像头上传图片

      技术树莓派如何定时通过摄像头上传图片这篇文章将为大家详细讲解有关树莓派如何定时通过摄像头上传图片,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、安装抓图软件fswebcamsudo

      攻略 2021年11月20日
    • Lammps分子动力学软件MPI并行教程是什么

      技术Lammps分子动力学软件MPI并行教程是什么Lammps分子动力学软件MPI并行教程是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获

      攻略 2021年10月20日