当前位置:首页 > 开发 > 编程语言 > 编程 > 正文

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

发表于: 2012-11-27   作者:cuisuqiang   来源:转载   浏览次数:
摘要: 需要的包和测试的代码下载附件!   如果需要将不同的日志打印到不同的地方,则需要定义不同的Appender,然后定义每一个 Appender的日志级别、打印形式、输出位置!   配置log4j.properties文件如下: ###################################################################

需要的包和测试的代码下载附件!

 

如果需要将不同的日志打印到不同的地方,则需要定义不同的Appender,然后定义每一个 Appender的日志级别、打印形式、输出位置!

 

配置log4j.properties文件如下:

#########################################################################################
# 日志信息配置
LOG_DIR=c://logtest/
log4j.rootLogger=WARN,rootlog,logSay
#########################################################################################
# 主日志控制 1G 30个循环文件 记录所有打印内容,不需要可以取消
log4j.appender.rootlog=org.apache.log4j.DailyRollingFileAppender
log4j.appender.rootlog.file=${LOG_DIR}/logtest.log
log4j.appender.rootlog.layout=org.apache.log4j.PatternLayout
log4j.appender.rootlog.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################
# 打印到控制台
log4j.appender.logSay=org.apache.log4j.ConsoleAppender
log4j.appender.logSay.Target=System.out
log4j.appender.logSay.layout=org.apache.log4j.PatternLayout
log4j.appender.logSay.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################
# test日志打印 10M 2个循环文件
log4j.logger.com.cui.log.test1=warn,test
log4j.appender.test=org.apache.log4j.RollingFileAppender
log4j.appender.test.MaxFileSize=10240KB
log4j.appender.test.MaxBackupIndex=2
log4j.appender.test.File=${LOG_DIR}/test.log
log4j.appender.test.layout=org.apache.log4j.PatternLayout
log4j.appender.test.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################
# test2日志打印 10M 2个循环文件
log4j.logger.com.cui.log.test2=debug,test2
log4j.appender.test2=org.apache.log4j.RollingFileAppender
log4j.appender.test2.MaxFileSize=10240KB
log4j.appender.test2.MaxBackupIndex=2
log4j.appender.test2.File=${LOG_DIR}/test2.log
log4j.appender.test2.layout=org.apache.log4j.PatternLayout
log4j.appender.test2.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n
#########################################################################################

 

定义了一个主输出配置,然后定义了两个包的各自打印行为:

package com.cui.log.test1;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
 * @说明 日志打印测试
 * @author 崔素强
 * @version 1.0
 * @since
 */
public class Test1 {
	/**
	 * 日志记录对象
	 */
	private static Log log = LogFactory.getLog(Test1.class);
	/**
	 * 测试
	 * @param args
	 */
	public static void main(String[] args) {
		log.debug("Test1");
		log.warn("Test1");
		log.info("Test1");
		log.error("Test1");
	}
}

 

另外一个不同包的代码:

package com.cui.log.test2;
import java.io.IOException;
import org.apache.commons.logging.Log; 
import org.apache.commons.logging.LogFactory;
/**
 * @说明 日志打印测试
 * @author 崔素强
 * @version 1.0
 * @since
 */
public class Test2 {
	/**
	 * 日志记录对象
	 */
	private static Log log = LogFactory.getLog(Test2.class);
	/**
	 * 测试
	 * @param args
	 */
	public static void main(String[] args) throws IOException {
		log.debug("Test2");
		log.warn("Test2");
		log.info("Test2");
		log.error("Test2");
	}
}

 

我们对两个不同打印的日志级别输出是不一样的,控制台也会根据各自配置进行打印,运行两个类!

控制台:

2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1

 

另外一个:

2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2

 

看输出文件打印:

主文件logtest.log:

2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1
2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2

 

测试1文件test.log:

2012-11-27 14:03:50 [com.cui.log.test1.Test1-21]-[WARN] Test1
2012-11-27 14:03:50 [com.cui.log.test1.Test1-23]-[ERROR] Test1

 

测试2文件test2.log:

 

2012-11-27 14:04:06 [com.cui.log.test2.Test2-21]-[DEBUG] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-22]-[WARN] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-23]-[INFO] Test2
2012-11-27 14:04:06 [com.cui.log.test2.Test2-24]-[ERROR] Test2

 

请您到ITEYE网站看原创,谢谢!

http://cuisuqiang.iteye.com/ !

自建博客地址:http://www.javacui.com/ ,内容与ITEYE同步!

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

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
使用场景:如需要进行性能调优,需要将执行时间单独输入到一个日志文件中 其中,log4j的配置 log4j.
环境:MyEclipse 6.5 问题:当一个工程使用其他工程的类时无法导入。 解决:工程------->右键---
环境:MyEclipse 6.5 问题:当一个工程使用其他工程的类时无法导入。 解决:工程------->右键---
在应用服务中 记录用户行为 记录日志是很好的方法, Log4j日志级别 不能日志需求记录到不同的日志文
接上回继续,项目开发好以后,通常要在多个环境部署,象我们公司多达5种环境:本机环境(local)、(开
一直听说intellij idea的大名,经过半天的折腾,终于安装上了(可恶,官网竟然被墙了!!!!!!)
由于个人口味差异,我妈爱看的电视节目我一般不爱看,反之亦然。这就像一个逆向功能的豆瓣网,只要
今天为了验证一段JS代码,就随手建了一个HTML文档,写了如下代码: 结果运行了之后发现JS代码根本就
关于火车票案例中 synchronized放在代码哪里的解释: 案例1: 火车票案例 特点: 多窗口下执行的同
使用虚拟串口在主机上添加一对串口COM2与COM3。 在虚拟机中添加一个虚拟串口,可以选择COM2或COM3,
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号