logger4j.properties和log4j.xml的常用配置(干货)

  1. 背景:不介绍了,日志对于一个项目的重要性大家都懂的;
  2. 直接上代码(含注释说明)
    1. log4j.xml的
      1. <?xml version="1.0" encoding="UTF-8"?>
        <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
        
        <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
        
            <!--
               * 1. 一个appender子元素定义一个日志输出目的地
               * 2. 一个logger子元素定义一个日志写出器
            -->
            <!-- catalina.out -->
            <appender name="consoleAppend" class="org.apache.log4j.ConsoleAppender" >
                <layout class="org.apache.log4j.PatternLayout">
                    <param name="ConversionPattern" value="%-d{yyyy-MM-dd HH:mm:ss} [%5p][%t][%c{1}]-[%M] %m%n" />
                </layout>
            </appender>
        
            <!-- error log -->
            <appender name="errorAppend" class="org.apache.log4j.DailyRollingFileAppender">
                <param name="File" value="${webapp.root}/logs/error/error.html" />
                <param name="Append" value="true" />
                <param name="DatePattern" value="yyyy-MM-dd-HH-mm‘.html‘"/>
                <param name="MaxBackupIndex" value="10" />
                <param name="MaxFileSize" 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>
    2. 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>
    3. 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");
时间: 2024-10-05 05:50:31

logger4j.properties和log4j.xml的常用配置(干货)的相关文章

log4j配置参考手册:log4j.properties和log4j.xml两种格式

log4j是Java Web开发中,最常用的日志组件之一.网上关于log4j的配置满天飞,我主要是从网上学习的配置.之前的很多年,主要使用log4j.properties这种格式.后来,项目中boss使用了log4j.xml这种配置.   关于xml配置,之前也用过,主要觉得麻烦,而且还要手动配置listener,所以基本不用.   和boss交流了下,发现xml格式的配置,语法更全面.我主要发现了2种"高端用途" :1.业务日志与系统日志相分离.(这个比较有价值)2.配置过滤器. (

log4j.xml简介

前言 上篇我们刚介绍了log4j.properties,但是log4j除了提供了properties的配置文件还有xml配置文件,但是目前大家还是使用log4j.xml的较多,因为它可以支持log4j.properties所不能支持的一些特性. 正题 1. log4j.properties VS log4j.xml 1) Log4j在执行的时候一般是先找log4j.xml然后再找log4j.properties. 但是配置文件需要放置到src文件夹下. 2) properties文件比xml文件

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

1,导入log4j  jar包; 2,配置log4j.xml或log4j.properties文件; ----------------------------------------------------------------------------------------------------------- <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuratio

软件开发工程师(JAVA)中级考试大纲-----四(四)Log4J的原理及配置;Log4J常用的API;在项目中应用日志框架Log4J关键类和接口介绍;Java properties配置文件log

log4j Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件,甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护进程等:我们也可以控制每一条日志的输出格式:通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程.最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码. 1定义 log4j--log for java(java的日志) 在强调可重用组件开发的今天,除了

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

一:测试环境与log4j(一)--为什么要使用log4j?一样,这里不再重述 二:老规矩,先来个栗子,然后再聊聊感受 (1)这里栗子有一点特别呀!给出了包名唉!想必有用,是的,配置文件中要特别说明一下的 package test.log4j.test8; import org.apache.log4j.LogManager; import org.apache.log4j.Logger; import org.apache.log4j.xml.DOMConfigurator; /** * Cre

log4j.xml与log4j.dtd的配置详细说明与使用

1.log4j.dtd .dtd文件是对相应.xml进行约束验证用的.这里不做介绍了,详细见上一篇关于dtd的介绍:xml基础.DTD验证.Schema验证 log4j.dtd的文件: <?xml version="1.0" encoding="UTF-8" ?> <!-- Authors: Chris Taylor, Ceki Gulcu. --> <!-- Version: 1.2 --> <!-- A configur

log4j.xml配置示例

这是log4j1.x版本讲解,log4j-1.2.16.jar    1. 一般的log4j.xml的两种配置方式: 1.Logger 完成日志信息的处理定义输出的层次和决定信息是否输出DEBUG<INFO<WARN<ERROR 2.Appender 设置日志信息的去向常用的:org.apache.log4j.ConsoleAppender(控制台)org.apache.log4j.FileAppender(文件)org.apache.log4j.DailyRollingFileAppe

Maven pom.xml 全配置(一)常用配置

Maven pom.xml 全配置(一)常用配置 这里贴出一个Maven中出现频率较高的配置参数注释,方便理解项目中Maven的配置具体的作用.如果在此博文中没有找到你想看到的参数,可以移步Maven pom.xml 全配置(二)不常用配置 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:sc

Maven pom.xml 全配置(二)不常用配置

Maven pom.xml 全配置(二)不常用配置 这里贴出Maven pom.xml文件中使用率较少的配置参数,如果此篇文档中没有找到你想要的参数,移步Maven pom.xml 全配置(一)常用配置 <!-- 项目创建年份,4位数字.当产生版权信息时需要使用这个值. --> <inceptionYear /> <!-- 描述了这个项目构建环境中的前提条件. --> <prerequisites> <!-- 构建该项目或使用该插件所需要的Maven的