文档章节

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

hebad
 hebad
发布于 2014/09/27 10:49
字数 1426
阅读 21725
收藏 102
  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");



© 著作权归作者所有

hebad
粉丝 16
博文 100
码字总数 11190
作品 0
杭州
技术主管
私信 提问
加载中

评论(3)

John-HZ
John-HZ
请问 com.raycloud.bizlogger.LoggerFilter是那个jar
hebad
hebad 博主

引用来自“dongen”的评论

如果是新版本log4j配置就好了
新版本还没去了解,有什么实用的新功能?
绝色
绝色
如果是新版本log4j配置就好了
OSChina 技术周刊第二期

每周技术抢先看,总有你想要的! 移动开发 【软件】Google Android 官方培训课程中文版 【博客】iOS开发之Swift调用Objective-C代码 【博客】教你爱上Blocks(闭包)(iOS) 【博客】uick-co...

OSC编辑部
2014/09/28
12.1K
34
jboss log4j冲突分析与解决

Log4j作为日志组件被大多数的系统所使用,Jboss也不例外的采用了Log4j作为它的日志输出组件。 但在使用JBoss时,很多人经常碰到一些冲突,这些冲如自己配置的log4j文件无效,系统抛org.jboss...

职通网
2012/07/16
672
0
Log4j.xml配置日志按级别过滤并将指定级别的日志发送到ActiveMQ

在之前的一篇博客《Spring+Log4j+ActiveMQ实现远程记录日志——实战+分析》的评论中,有同学提到这种方式应该要能根据日志级别设置来决定是否发送到mq,不然会大量占用网络资源。于是经过了一...

摆渡者
2015/11/27
4.3K
0
YMP框架学习笔记(二)------基于YMP框架搭建WEB应用程序

大神的YMP框架:https://github.com/suninformation/ymateplatform.git 1. 新建Maven project 打开新建项目对话框,选择Maven Project(File->New->Object->Maven->Maven Project) 直接nex......

小樓聽風雨
2014/07/01
1K
0
maven插件maven-resources-plugin如何配置拷贝更换目录

resources目录如下: resources目录下有一个config目录 config目录下有3个目录,dev,staging,production pom.xml里面配置了profile 为了达到把 resources目录下的所有文件和目录(除了config)...

西夏一品堂
2015/06/12
5.2K
4

没有更多内容

加载失败,请刷新页面

加载更多

java通过ServerSocket与Socket实现通信

首先说一下ServerSocket与Socket. 1.ServerSocket ServerSocket是用来监听客户端Socket连接的类,如果没有连接会一直处于等待状态. ServetSocket有三个构造方法: (1) ServerSocket(int port);...

Blueeeeeee
今天
6
0
用 Sphinx 搭建博客时,如何自定义插件?

之前有不少同学看过我的个人博客(http://python-online.cn),也根据我写的教程完成了自己个人站点的搭建。 点此:使用 Python 30分钟 教你快速搭建一个博客 为防有的同学不清楚 Sphinx ,这...

王炳明
昨天
5
0
黑客之道-40本书籍助你快速入门黑客技术免费下载

场景 黑客是一个中文词语,皆源自英文hacker,随着灰鸽子的出现,灰鸽子成为了很多假借黑客名义控制他人电脑的黑客技术,于是出现了“骇客”与"黑客"分家。2012年电影频道节目中心出品的电影...

badaoliumang
昨天
15
0
很遗憾,没有一篇文章能讲清楚线程的生命周期!

(手机横屏看源码更方便) 注:java源码分析部分如无特殊说明均基于 java8 版本。 简介 大家都知道线程是有生命周期,但是彤哥可以认真负责地告诉你网上几乎没有一篇文章讲得是完全正确的。 ...

彤哥读源码
昨天
16
0
jquery--DOM操作基础

本文转载于:专业的前端网站➭jquery--DOM操作基础 元素的访问 元素属性操作 获取:attr(name);$("#my").attr("src"); 设置:attr(name,value);$("#myImg").attr("src","images/1.jpg"); ......

前端老手
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部