`

Log4J.properties中对单个文件或包进行多中Log配置

阅读更多

 

log4j.rootCategory

  • 是对根类的设置,如不说明,以下的子类都要继承这些设置

 

log4j.category.*

  • 是对自定义类的设置,可以对类、包和工程单独设置

Category的家族关系是通过“.”来说明的,比如x是x.y的父类。
默认情况下,子类要继承父类的全部设置,比如:

  • log4j.rootCategory=INFO, dest1
  • log4j.category.MyCategory=DEBUG
  1. dest1会输出INFO以上的消息
  2. 对于Category logger = Category.getInstance("MyCategory")会输出DEBUG以上的消息,因为MyCategory继承了根类的设置,输出到dest1

如果使用下面的设置,每条消息会在dest1中输出两次:

  • log4j.rootCategory = INFO, dest1
  • log4j.category.MyCategory = DEBUG, dest1

记住,MyCategory继承了根类的设置。
可以指定子类不继承父类的设置,方法是指定log4j.additivity.*=false,如上例中:

  • log4j.rootCategory = INFO, dest1
  • log4j.additivity.MyCategory = false
  • log4j.category.MyCategory = DEBUG, dest1

 

2,http://wangjc-opal.iteye.com/blog/309924

log4j的强大功能无可置疑,但实际应用中免不了遇到某个功能需要输出独立的日志文件的情况,怎样才能把所需的内容从原有日志中分离,形成单独的日志文件呢?其实只要在现有的log4j基础上稍加配置即可轻松实现这一功能。

  先看一个常见的log4j.properties文件,它是在控制台和myweb.log文件中记录日志:

log4j.rootLogger=DEBUG, stdout, logfile

 

log4j.category.org.springframework=ERROR

log4j.category.org.apache=INFO

 

log4j.appender.stdout=org.apache.log4j.ConsoleAppender

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n

 

log4j.appender.logfile=org.apache.log4j.RollingFileAppender

log4j.appender.logfile.File=${myweb.root}/WEB-INF/log/myweb.log

log4j.appender.logfile.MaxFileSize=512KB

log4j.appender.logfile.MaxBackupIndex=5

log4j.appender.logfile.layout=org.apache.log4j.PatternLayout

log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n

  

如果想对不同的类输出不同的文件(以cn.com.Test为例),先要在Test.java中定义:

private static Log logger = LogFactory.getLog(Test.class);

  然后在log4j.properties中加入:

log4j.logger.cn.com.Test= DEBUG, test

log4j.appender.test=org.apache.log4j.FileAppender

log4j.appender.test.File=${myweb.root}/WEB-INF/log/test.log

log4j.appender.test.layout=org.apache.log4j.PatternLayout

log4j.appender.test.layout.ConversionPattern=%d %p [%c] - %m%n

  也就是让cn.com.Test中的logger使用log4j.appender.test所做的配置。

 

  但是,如果在同一类中需要输出多个日志文件呢?其实道理是一样的,先在Test.java中定义:

private static Log logger1 = LogFactory.getLog("myTest1");

private static Log logger2 = LogFactory.getLog("myTest2");

  然后在log4j.properties中加入:

log4j.logger.myTest1= DEBUG, test1

log4j.appender.test1=org.apache.log4j.FileAppender

log4j.appender.test1.File=${myweb.root}/WEB-INF/log/test1.log

log4j.appender.test1.layout=org.apache.log4j.PatternLayout

log4j.appender.test1.layout.ConversionPattern=%d %p [%c] - %m%n

  

log4j.logger.myTest2= DEBUG, test2

log4j.appender.test2=org.apache.log4j.FileAppender

log4j.appender.test2.File=${myweb.root}/WEB-INF/log/test2.log

log4j.appender.test2.layout=org.apache.log4j.PatternLayout

log4j.appender.test2.layout.ConversionPattern=%d %p [%c] - %m%n

  也就是在用logger时给它一个自定义的名字(如这里的"myTest1"),然后在log4j.properties中做出相应配置即可。别忘了不同日志要使用不同的logger(如输出到test1.log的要用logger1.info("abc"))。

 

  还有一个问题,就是这些自定义的日志默认是同时输出到log4j.rootLogger所配置的日志中的,如何能只让它们输出到自己指定的日志中呢?别急,这里有个开关:

log4j.additivity.myTest1 = false

  它用来设置是否同时输出到log4j.rootLogger所配置的日志中,设为false就不会输出到其它地方啦!注意这里的"myTest1"是你在程序中给logger起的那个自定义的名字!

如果你说,我只是不想同时输出这个日志到log4j.rootLogger所配置的logfile中,stdout里我还想同时输出呢!那也好办,把你的log4j.logger.myTest1 = DEBUG, test1改为下式就OK啦!

log4j.logger.myTest1=DEBUG, test1

=======================

example:

#ident "%W"
#it will log every thing
log4j.rootCategory=INFO

log4j.logger.actions=INFO, R
log4j.logger.dto=INFO, R
log4j.logger.util=INFO, R
log4j.logger.delegators=INFO, R
log4j.logger.ejbcore=INFO, R
log4j.logger.javacore=INFO, R
log4j.logger.xxx=INFO, R
log4j.logger.loanclient=INFO, R
log4j.logger.loan.position=INFO, R
log4j.logger.org.springframework=INFO, R

#log4j.debug=true
#log4j.disable=INFO
#log4j.disable=DEBUG
#log4j.appender.stdout=org.apache.log4j.ConsoleAppender
#log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

# Pattern to output the caller's file name and line number.
#log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n

log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=@LOAN_ROOT@/log/xxx.log

log4j.appender.R.MaxFileSize=50000KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=3

log4j.appender.R.layout=org.apache.log4j.PatternLayout
#log4j.appender.R.layout=org.apache.log4j.TTCCLayout
log4j.appender.R.layout.ConversionPattern=%d{MM/dd/yyyy HH:mm:ss, SSS} [%t] [%5p] %c{1}:[%L] - %m%n

# =============== POST TRADE PROPERTIES =====================
log4j.logger.loan.tesgateway=INFO, POSTTRADE
log4j.logger.loan.posttrade=INFO, POSTTRADE
log4j.logger.loan.clearpar=INFO, POSTTRADE
log4j.logger.loan.liveupdate=INFO, POSTTRADE
log4j.logger.org.springframework=INFO, POSTTRADE

log4j.appender.POSTTRADE=org.apache.log4j.RollingFileAppender
log4j.appender.POSTTRADE.File=@LOAN_ROOT@/log/post_trade.log

log4j.appender.POSTTRADE.MaxFileSize=50000KB
# Keep one backup file
log4j.appender.POSTTRADE.MaxBackupIndex=3

log4j.appender.POSTTRADE.layout=org.apache.log4j.PatternLayout
#log4j.appender.POSTTRADE.layout=org.apache.log4j.TTCCLayout
log4j.appender.POSTTRADE.layout.ConversionPattern=%d{MM/dd/yyyy HH:mm:ss, SSS} [%t] [%5p] %c{1}:[%L] - %m%n

# =============== VAILDATION SERVICE PROPERTIES =====================
log4j.appender.VAILDATION=org.apache.log4j.RollingFileAppender
log4j.appender.VAILDATION.File=@LOAN_ROOT@/log/valcalc_service.log

log4j.appender.VAILDATION.MaxFileSize=50000KB
# Keep one backup file
log4j.appender.VAILDATION.MaxBackupIndex=1

log4j.appender.VAILDATION.layout=org.apache.log4j.PatternLayout
#log4j.appender.VAILDATION.layout=org.apache.log4j.TTCCLayout
log4j.appender.VAILDATION.layout.ConversionPattern=%d{MM/dd/yyyy HH:mm:ss, SSS} [%t] [%5p] %c{1}:[%L] - %m%n

log4j.logger.loan.calculator=INFO, VAILDATION
log4j.logger.loan.common=INFO, VAILDATION
log4j.logger.loan.framework=INFO, VAILDATION
log4j.logger.loan.validator=INFO, VAILDATION
log4j.logger.loan.propertiescache=INFO, VAILDATION
log4j.logger.loan.account=INFO, VAILDATION

private Category cat = Category.getInstance(loan.posttrade.common.publisher.GFITradePublisher.class.getName());

 this will be logged in post_trade.log

分享到:
评论

相关推荐

    log4j.properties详细配置解释与例子

    `log4j.properties`是Apache Log4j库中用于配置日志记录行为的核心配置文件。下面将详细解析`log4j.properties`的配置项及其作用,同时提供实例来加深理解。 ### 1. Logger 日志记录的核心是`Logger`,它是Log4j中...

    Log4J_全能配置文件.pdf

    ### Log4J 全能配置文件详解 #### 一、概述 Log4J是一款非常流行的Java日志框架,被广泛应用于各种规模的应用程序中。它提供了灵活的日志记录机制,可以将日志输出到不同的目的地,如控制台、文件、数据库等,并且...

    MyBatis基本CRUD与动态SQL(带log4j.properties).zip

    在日志配置文件`log4j.properties`中,我们可以设置不同级别的日志输出,如DEBUG、INFO、WARN、ERROR等。对于MyBatis来说,启用合适的日志级别可以帮助我们追踪SQL执行情况,分析性能瓶颈,以及定位潜在的问题。例如...

    log4j.properties

    ### 关于 log4j.properties 配置文件的理解与解析 #### 一、log4j.properties 配置文件格式概述 `log4j.properties` 文件是 Apache Log4j 框架用于配置日志记录行为的核心配置文件。Log4j 是 Java 开发中广泛使用...

    log4j.zip 项目日志

    解压“log4j.zip”后,我们通常会找到一个名为“log4j.properties”或“log4j.xml”的配置文件,这是Log4j的核心配置文件。例如,以下是一个简单的配置示例: ```properties # log4j.properties log4j.rootLogger=...

    log4j与web.xml的配置

    2. **Log4j配置文件(log4j.properties或log4j.xml)** - 在Java项目中,通常会有一个log4j配置文件,用于定义日志记录的级别、输出方式和格式。 - 示例配置: ``` log4j.rootLogger=DEBUG, FILE log4j....

    log4j.properties参数详解word

    在log4j中,有ERROR、WARN、INFO、DEBUG四种级别。ERROR用于记录严重的错误信息,通常是程序无法正常运行的情况。WARN表示一般警告,例如会话丢失等非致命问题。INFO级别常用于常规信息的记录,如用户登录、登出等。...

    log4j中的dtd文件

    在Log4j的上下文中,`log4j.dtd`是Log4j配置文件(通常命名为`log4j.properties`或`log4j.xml`)的DTD,它定义了配置文件中可以使用的元素、属性及其结构,确保配置文件的合法性。 在Log4j的配置文件中,我们可以...

    tomcat下用Log4j 按文件大小,生成catalina.out日志文件

    在Tomcat中配置Log4j,可以实现按照文件大小生成日志文件,如`catalina.out`,从而避免单个日志文件过大导致的管理不便。 首先,我们需要理解Log4j的工作原理。Log4j主要包括三个核心组件:Logger(日志器)、...

    Log4j的相关jar包和配置文件

    本资料主要包含了Log4j的相关jar包和配置文件,下面我们将详细讨论Log4j的关键概念、配置以及其在实际项目中的应用。 1. **Log4j组件** - **Logger**: 日志的核心组件,负责生成日志事件。开发人员通过创建Logger...

    Log4jToRollingFileAppender.zip

    使用`RollingFileAppender`首先需要在`log4j.properties`或`log4j.xml`配置文件中进行设置。例如: ``` log4j.appender.RFA=org.apache.log4j.DailyRollingFileAppender log4j.appender.RFA.File=/path/to/log...

    Log4j配置文件详细说明

    首先,Log4j的配置文件通常是`log4j.properties`或`log4j.xml`,用于定义日志输出的行为。这里我们主要讨论基于文本格式的`log4j.properties`。在这个文件中,你可以设置不同的日志级别(DEBUG, INFO, WARN, ERROR, ...

    log4j很实用配置

    ### log4j 实用配置详解 #### 一、配置根 Logger 在 Log4j 的配置过程中,根 Logger 是一个非常重要的概念。它负责全局的日志级别设置以及日志信息的输出方式。 - **配置语法**:`log4j.rootLogger=, , ...

    log4j多文件配置

    ### Log4j多文件配置详解 #### 一、引言 在软件开发过程中,日志管理是维护系统稳定性与可追踪性的重要手段之一。而Log4j作为一款成熟且广泛使用的日志框架,在处理复杂的日志需求方面表现出了强大的功能。特别是...

    WAS上log4j日志不能输出(ibatis)sql语句解决办法[借鉴].pdf

    WAS 上 log4j 日志不能...解决 WAS 上 log4j 日志不能输出(ibatis)sql 语句的问题需要改变 WAS 的默认 LogFactory 实现类,使其使用 log4j 框架下的 LogFactory 实现类,并且需要正确配置 log4j.properties 文件。

    java log4j配置大全

    ### Java Log4j 配置详解 #### 一、Log4j 概述 Log4j 是 Apache 的一个开源项目,被广泛应用于 Java 应用程序的日志记录中。通过 Log4j,开发者可以轻松控制日志信息的输出目的地、格式以及级别。这使得日志的管理...

    SSH框架中配置log4j的方法

    1. **动态调整日志级别**:通过修改`log4j.properties`文件中的配置,可以在不重启Web应用的情况下调整日志级别和策略。这对于生产环境中的调试尤为重要,因为它允许开发者根据实际需求灵活地调整日志记录的详细程度...

    Log4j 相对路径配置

    首先,在`Web.xml`文件中,我们需要进行一些配置来使Log4j在Web应用启动时初始化。`<context-param>`标签用于设置Log4j的相关参数: 1. `<param-name>webAppRootKey</param-name>` 和 `<param-value>webApp.root...

    log4j2配置文件,按照文件大小划分日志,保存日期天数内的日志等

    log4j2配置文件,按照文件大小划分日志,保存日期天数内的日志,指纹日志命名规则,日志输出等级等功能

Global site tag (gtag.js) - Google Analytics