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.properties`或`log4j.xml`)中定义多个Appender。Appender是Log4j中负责将日志信息输出到指定目的地的组件,例如文件、控制台、网络...
总结起来,通过Log4j,我们可以轻松地定制日志输出,包括创建多个自定义日志文件,指定不同的日志级别,以及动态调整日志路径。这对于大型项目和复杂系统的监控与调试至关重要。正确配置和使用Log4j能够帮助开发者更...
此外,Log4j还支持过滤器(Filter)和自定义日志处理器,可以进一步精细化日志管理。例如,我们可以通过自定义Filter来控制特定类或方法的日志输出,或者编写自定义Layout来实现特殊的日志格式。 总结起来,`Log4j`...
- **日志级别**:Log4j支持多个日志级别,从低到高分别是TRACE, DEBUG, INFO, WARN, ERROR, FATAL。在配置文件中,可以设置每个logger或root logger的级别,控制输出的日志级别。 4. **日志输出格式** - **...
- `log4j.appender.FILE.File`:设置日志文件的输出路径。 - `log4j.appender.FILE.layout`:设置日志布局模式,这里使用了PatternLayout。 - `log4j.appender.FILE.layout.ConversionPattern`:定义日志输出的...
Log4j通过配置文件(通常是log4j.properties或log4j.xml)来设定日志输出级别、格式、目的地等参数。如果日志没有按预期输出,我们需要检查以下几个方面: 1. **配置文件**:确认配置文件是否正确包含在项目中,...
- 可以配置多个Appender,比如同时输出到控制台和文件,或者发送日志到远程服务器。 - 使用`%class`, `%method`, `%line`等占位符自定义日志格式,以便更好地定位问题。 - 通过调整`rootLogger`或特定logger的...
Log4j支持多个日志级别,包括DEBUG、INFO、WARN、ERROR和FATAL。这些级别按照严重程度递增,DEBUG是最详细的信息,而FATAL表示严重的系统错误。根据需求,我们可以选择性地记录不同级别的信息,以便在调试或监控时...
- **日志级别**:Log4j支持多个级别,包括`DEBUG`、`INFO`、`WARN`、`ERROR`和`FATAL`,每个级别对应不同的严重程度,开发者可以根据需求调整记录哪些级别的日志。 - **Appender**:Appender是日志输出的目标,...
2. **配置文件**:配置文件是Log4j的核心部分,它定义了日志输出的行为。通常,配置文件(如`log4j.properties`或`log4j.xml`)会被放置在项目源代码的`src`目录下,这样在编译后会自动包含到类路径中。配置文件可以...
配置Log4J是关键步骤,因为它决定了日志的输出级别、输出目的地、输出格式等多个方面。下面将详细介绍Log4J的配置。 **配置文件** Log4J的配置文件一般以.properties或.xml格式存在,用于定义日志行为。基本的配置...
Log4j是一款广泛使用的Java日志记录框架,其配置文件是整个系统日志管理的核心,允许开发者自定义日志的输出级别、输出目的地以及输出格式。这篇内容将深入讲解Log4j的配置细节。 首先,Log4j配置文件的基础结构...
Log4j的优势在于其灵活性,通过配置文件(如`log4j.properties`)即可调整设置,无需修改代码,且支持跨语言平台,如C、C++、.Net、PL/SQL等,便于构建多语言分布式系统的日志一致性。 配置Log4j主要分为三个步骤:...
Log4j提供了丰富的配置选项,允许用户自定义日志级别、输出目的地等。本文将基于提供的log4j.xml配置文件,详细解析其各项设置。 #### 二、log4j.xml配置文件结构 log4j.xml配置文件遵循XML格式,主要由以下几部分...
为了演示Log4j的使用,我们可以创建一个简单的Java应用,它使用配置的Log4j输出不同级别的日志消息。首先,创建`log4j.properties`文件,然后创建一个Java类: ```java // MyDemo.java import org.apache.log4j....
7. **Configuration(配置)**:Log4j的配置通常在`log4j.properties`或`log4j.xml`文件中进行,可以动态地改变日志行为。 压缩包内的`log4j.jar`文件是Log4j的二进制库,包含了所有Log4j的类和方法,你需要将它...
Log4j通过其丰富的配置选项,允许用户自定义日志级别、输出格式、目标位置等,极大地提升了日志处理的效率。 在提供的压缩包中,有两个关键文件:`log4j.txt`和`log4j日志文件路径的配置.txt`。`log4j.txt`很可能是...
此配置文件定义了两个 Appender——控制台输出 (`A1`) 和滚动文件输出 (`R`),并指定了各自的格式化规则和日志级别。 #### 三、Log4j 使用场景与最佳实践 1. **日志分级**:合理设置日志级别可以提高调试效率,并...
7. **配置文件的加载与更新**:在程序运行时,可以通过指定配置文件路径动态加载和更新Log4j配置。 8. **MDC(Mapped Diagnostic Context)与NDC(Nested Diagnostic Context)**:这两个特性可以帮助开发者在多...