`

log4j输出多个自定义日志文件,动态配置路径

阅读更多

1.    log4j输出多个自定义日志文件

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, stdout



2.动态配置路径

若程序需要的日志路径需要不断的变化,而又不可能每次都去改配置文件,那就要采取两种方法。

第一种

        log4j的配置文件支持windows的环境变量,格式类似velocity:${env},那我们就用环境变量表示可能会变化的路径。上文已使用“log4j.appender.test1.File=${myweb.root}/WEB-INF/log/test1.log”。

第二种

       这种方法是不用配置文件,而是在程序里用代码配置,代码是活的,所以路径肯定可以写活。示例如下:

view plaincopy to clipboardprint?
Logger myTest = Logger.getLogger("myTest");  
 
Layout layout = new PatternLayout("%d %p [%c] - %m%n");  
 
Appender appender = new FileAppender(layout, logFilePath);  
 
myTest.addAppender(appender); 
Logger myTest = Logger.getLogger("myTest");

Layout layout = new PatternLayout("%d %p [%c] - %m%n");

Appender appender = new FileAppender(layout, logFilePath);

myTest.addAppender(appender);



附:ConversionPattern参数的格式含义



%c 输出日志信息所属的类的全名
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy-MM-dd HH:mm:ss },输出类似:2002-10-18- 22:10:28
%f 输出日志信息所属的类的类名
%l 输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行
%m 输出代码中指定的信息,如log(message)中的message
%n 输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推
%r 输出自应用启动到输出该日志信息所耗费的毫秒数
%t 输出产生该日志事件的线程名

 

分享到:
评论

相关推荐

    log4j输出多个自定义路径的日志文件小例子

    要实现输出多个自定义路径的日志文件,我们需要在Log4j的配置文件(通常是`log4j.properties`或`log4j.xml`)中定义多个Appender。Appender是Log4j中负责将日志信息输出到指定目的地的组件,例如文件、控制台、网络...

    java自定义日志输出文件(log4j日志文件输出多个自定义日志文件)

    总结起来,通过Log4j,我们可以轻松地定制日志输出,包括创建多个自定义日志文件,指定不同的日志级别,以及动态调整日志路径。这对于大型项目和复杂系统的监控与调试至关重要。正确配置和使用Log4j能够帮助开发者更...

    Log4j 把不同包的日志打印到不同位置

    此外,Log4j还支持过滤器(Filter)和自定义日志处理器,可以进一步精细化日志管理。例如,我们可以通过自定义Filter来控制特定类或方法的日志输出,或者编写自定义Layout来实现特殊的日志格式。 总结起来,`Log4j`...

    log4j的详细配置,log4j.xml和log4j.properties,日志输出到文件,邮件,数据库,控制台等

    - **日志级别**:Log4j支持多个日志级别,从低到高分别是TRACE, DEBUG, INFO, WARN, ERROR, FATAL。在配置文件中,可以设置每个logger或root logger的级别,控制输出的日志级别。 4. **日志输出格式** - **...

    Tomcat 8.0.30 log4j配置

    - `log4j.appender.FILE.File`:设置日志文件的输出路径。 - `log4j.appender.FILE.layout`:设置日志布局模式,这里使用了PatternLayout。 - `log4j.appender.FILE.layout.ConversionPattern`:定义日志输出的...

    无法打出log4j日志的问题排查

    Log4j通过配置文件(通常是log4j.properties或log4j.xml)来设定日志输出级别、格式、目的地等参数。如果日志没有按预期输出,我们需要检查以下几个方面: 1. **配置文件**:确认配置文件是否正确包含在项目中,...

    log4j与web.xml的配置

    - 可以配置多个Appender,比如同时输出到控制台和文件,或者发送日志到远程服务器。 - 使用`%class`, `%method`, `%line`等占位符自定义日志格式,以便更好地定位问题。 - 通过调整`rootLogger`或特定logger的...

    log4j日志文件配置

    Log4j支持多个日志级别,包括DEBUG、INFO、WARN、ERROR和FATAL。这些级别按照严重程度递增,DEBUG是最详细的信息,而FATAL表示严重的系统错误。根据需求,我们可以选择性地记录不同级别的信息,以便在调试或监控时...

    一个Log4j配置文件,感觉还不错

    - **日志级别**:Log4j支持多个级别,包括`DEBUG`、`INFO`、`WARN`、`ERROR`和`FATAL`,每个级别对应不同的严重程度,开发者可以根据需求调整记录哪些级别的日志。 - **Appender**:Appender是日志输出的目标,...

    log4j配置文件及jar包

    2. **配置文件**:配置文件是Log4j的核心部分,它定义了日志输出的行为。通常,配置文件(如`log4j.properties`或`log4j.xml`)会被放置在项目源代码的`src`目录下,这样在编译后会自动包含到类路径中。配置文件可以...

    log4j的详细配置

    配置Log4J是关键步骤,因为它决定了日志的输出级别、输出目的地、输出格式等多个方面。下面将详细介绍Log4J的配置。 **配置文件** Log4J的配置文件一般以.properties或.xml格式存在,用于定义日志行为。基本的配置...

    Log4j详细配置

    Log4j是一款广泛使用的Java日志记录框架,其配置文件是整个系统日志管理的核心,允许开发者自定义日志的输出级别、输出目的地以及输出格式。这篇内容将深入讲解Log4j的配置细节。 首先,Log4j配置文件的基础结构...

    jjava日志文件log4j

    Log4j的优势在于其灵活性,通过配置文件(如`log4j.properties`)即可调整设置,无需修改代码,且支持跨语言平台,如C、C++、.Net、PL/SQL等,便于构建多语言分布式系统的日志一致性。 配置Log4j主要分为三个步骤:...

    log4j的配置

    Log4j提供了丰富的配置选项,允许用户自定义日志级别、输出目的地等。本文将基于提供的log4j.xml配置文件,详细解析其各项设置。 #### 二、log4j.xml配置文件结构 log4j.xml配置文件遵循XML格式,主要由以下几部分...

    log4j常用配置和Demo

    为了演示Log4j的使用,我们可以创建一个简单的Java应用,它使用配置的Log4j输出不同级别的日志消息。首先,创建`log4j.properties`文件,然后创建一个Java类: ```java // MyDemo.java import org.apache.log4j....

    log4j.zip和log4j.jar日志文档的处理

    7. **Configuration(配置)**:Log4j的配置通常在`log4j.properties`或`log4j.xml`文件中进行,可以动态地改变日志行为。 压缩包内的`log4j.jar`文件是Log4j的二进制库,包含了所有Log4j的类和方法,你需要将它...

    log4j配置文件

    Log4j通过其丰富的配置选项,允许用户自定义日志级别、输出格式、目标位置等,极大地提升了日志处理的效率。 在提供的压缩包中,有两个关键文件:`log4j.txt`和`log4j日志文件路径的配置.txt`。`log4j.txt`很可能是...

    log4j详细配置说明

    此配置文件定义了两个 Appender——控制台输出 (`A1`) 和滚动文件输出 (`R`),并指定了各自的格式化规则和日志级别。 #### 三、Log4j 使用场景与最佳实践 1. **日志分级**:合理设置日志级别可以提高调试效率,并...

    log4j 配置文件

    7. **配置文件的加载与更新**:在程序运行时,可以通过指定配置文件路径动态加载和更新Log4j配置。 8. **MDC(Mapped Diagnostic Context)与NDC(Nested Diagnostic Context)**:这两个特性可以帮助开发者在多...

Global site tag (gtag.js) - Google Analytics