`
snoopy7713
  • 浏览: 1148951 次
  • 性别: Icon_minigender_2
  • 来自: 火星郊区
博客专栏
Group-logo
OSGi
浏览量:0
社区版块
存档分类
最新评论

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

    博客分类:
  • java
 
阅读更多

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

 

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

 

配置log4j.properties文件如下:

Java代码  收藏代码
  1. #########################################################################################  
  2. # 日志信息配置  
  3. LOG_DIR=c://logtest/   
  4. log4j.rootLogger=WARN,rootlog,logSay  
  5. #########################################################################################  
  6. # 主日志控制 1G 30 个循环文件 记录所有打印内容,不需要可以取消  
  7. log4j.appender.rootlog=org.apache.log4j.DailyRollingFileAppender  
  8. log4j.appender.rootlog.file=${LOG_DIR}/logtest.log  
  9. log4j.appender.rootlog.layout=org.apache.log4j.PatternLayout  
  10. log4j.appender.rootlog.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n  
  11. #########################################################################################  
  12. # 打印到控制台  
  13. log4j.appender.logSay=org.apache.log4j.ConsoleAppender  
  14. log4j.appender.logSay.Target=System.out  
  15. log4j.appender.logSay.layout=org.apache.log4j.PatternLayout  
  16. log4j.appender.logSay.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n  
  17. #########################################################################################  
  18. # test日志打印 10M 2 个循环文件  
  19. log4j.logger.com.cui.log.test1=warn,test  
  20. log4j.appender.test=org.apache.log4j.RollingFileAppender  
  21. log4j.appender.test.MaxFileSize=10240KB  
  22. log4j.appender.test.MaxBackupIndex=2   
  23. log4j.appender.test.File=${LOG_DIR}/test.log  
  24. log4j.appender.test.layout=org.apache.log4j.PatternLayout  
  25. log4j.appender.test.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n  
  26. #########################################################################################  
  27. # test2日志打印 10M 2 个循环文件  
  28. log4j.logger.com.cui.log.test2=debug,test2  
  29. log4j.appender.test2=org.apache.log4j.RollingFileAppender  
  30. log4j.appender.test2.MaxFileSize=10240KB  
  31. log4j.appender.test2.MaxBackupIndex=2   
  32. log4j.appender.test2.File=${LOG_DIR}/test2.log  
  33. log4j.appender.test2.layout=org.apache.log4j.PatternLayout  
  34. log4j.appender.test2.layout.ConversionPattern=%-d{yyyy-MM-dd HH\:mm\:ss} [%c-%L]-[%p] %m%n  
  35. #########################################################################################  

 

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

Java代码  收藏代码
  1. package  com.cui.log.test1;  
  2. import  org.apache.commons.logging.Log;  
  3. import  org.apache.commons.logging.LogFactory;  
  4. /**  
  5.  * @说明 日志打印测试  
  6.  * @author 崔素强  
  7.  * @version 1.0  
  8.  * @since  
  9.  */   
  10. public   class  Test1 {  
  11.     /**  
  12.      * 日志记录对象  
  13.      */   
  14.     private   static  Log log = LogFactory.getLog(Test1. class );  
  15.     /**  
  16.      * 测试  
  17.      * @param args  
  18.      */   
  19.     public   static   void  main(String[] args) {  
  20.         log.debug("Test1" );  
  21.         log.warn("Test1" );  
  22.         log.info("Test1" );  
  23.         log.error("Test1" );  
  24.     }  
  25. }  

 

另外一个不同包的代码:

Java代码  收藏代码
  1. package  com.cui.log.test2;  
  2. import  java.io.IOException;  
  3. import  org.apache.commons.logging.Log;   
  4. import  org.apache.commons.logging.LogFactory;  
  5. /**  
  6.  * @说明 日志打印测试  
  7.  * @author 崔素强  
  8.  * @version 1.0  
  9.  * @since  
  10.  */   
  11. public   class  Test2 {  
  12.     /**  
  13.      * 日志记录对象  
  14.      */   
  15.     private   static  Log log = LogFactory.getLog(Test2. class );  
  16.     /**  
  17.      * 测试  
  18.      * @param args  
  19.      */   
  20.     public   static   void  main(String[] args)  throws  IOException {  
  21.         log.debug("Test2" );  
  22.         log.warn("Test2" );  
  23.         log.info("Test2" );  
  24.         log.error("Test2" );  
  25.     }  
  26. }  

 

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

控制台:

Java代码  收藏代码
  1. 2012 - 11 - 27   14 : 03 : 50  [com.cui.log.test1.Test1- 21 ]-[WARN] Test1  
  2. 2012 - 11 - 27   14 : 03 : 50  [com.cui.log.test1.Test1- 23 ]-[ERROR] Test1  

 

另外一个:

Java代码  收藏代码
  1. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 21 ]-[DEBUG] Test2  
  2. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 22 ]-[WARN] Test2  
  3. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 23 ]-[INFO] Test2  
  4. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 24 ]-[ERROR] Test2  

 

看输出文件打印:

主文件logtest.log:

Java代码  收藏代码
  1. 2012 - 11 - 27   14 : 03 : 50  [com.cui.log.test1.Test1- 21 ]-[WARN] Test1  
  2. 2012 - 11 - 27   14 : 03 : 50  [com.cui.log.test1.Test1- 23 ]-[ERROR] Test1  
  3. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 21 ]-[DEBUG] Test2  
  4. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 22 ]-[WARN] Test2  
  5. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 23 ]-[INFO] Test2  
  6. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 24 ]-[ERROR] Test2  

 

测试1文件test.log:

Java代码  收藏代码
  1. 2012 - 11 - 27   14 : 03 : 50  [com.cui.log.test1.Test1- 21 ]-[WARN] Test1  
  2. 2012 - 11 - 27   14 : 03 : 50  [com.cui.log.test1.Test1- 23 ]-[ERROR] Test1  

 

测试2文件test2.log:

 

Java代码  收藏代码
  1. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 21 ]-[DEBUG] Test2  
  2. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 22 ]-[WARN] Test2  
  3. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 23 ]-[INFO] Test2  
  4. 2012 - 11 - 27   14 : 04 : 06  [com.cui.log.test2.Test2- 24 ]-[ERROR] Test2  

 

 

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

http://cuisuqiang.iteye.com/  !

  • log.zip (414.2 KB)
  • 下载次数: 3
分享到:
评论

相关推荐

    Log4j2实现不同线程不同级别日志输出到不同的文件中

    本教程将详细讲解如何利用Log4j2实现不同线程不同级别的日志输出到不同的文件中,这对于大型分布式系统或者多线程应用的日志管理和分析尤为关键。 首先,Log4j2的核心在于其配置文件(通常为log4j2.xml或log4j2....

    log4j2异步多线程打印

    此外,Log4j2还支持配置多个Appenders(日志输出目的地),这样不同的线程可以根据需求将日志输出到不同的文件或位置。 **Log4j2配置** 在Log4j2中,配置文件通常使用XML、JSON或YAML格式,可以灵活定义日志级别、...

    log4j 日志打印

    《深入理解Log4j日志打印》 在Java开发领域,日志打印是不可或缺的一环,它对于系统调试、性能监控、故障排查等都起着至关重要的作用。Log4j作为Java中最常用的日志框架之一,深受广大开发者喜爱。本文将深入探讨...

    mybatis,log4j打印日志到后台和文件

    本文将深入探讨如何在 MyBatis 中配置 Log4j,实现日志同时输出到后台控制台和文件。 1. **日志框架集成** 在 MyBatis 中,我们通常会依赖日志框架如 Log4j、Logback 或 JDK 内置的日志系统。Log4j 以其强大的功能...

    log4j-如何将日志打印到控制台:log4j-demo.zip

    《深入理解Log4j:如何将日志打印到控制台》 日志系统在软件开发中扮演着至关重要的角色,它能帮助开发者追踪程序运行状态、定位错误和调试问题。Log4j作为Java世界中最流行的日志框架之一,因其强大的功能和灵活性...

    老生常谈Log4j和Log4j2的区别(推荐)

    相比之下,Log4j2就比较简单,我们只需要把log4j2.xml文件放到工程的resource目录下就行了。 Log调用 Log4j和Log4j2的调用都是很简单的。Log4j需要import org.apache.log4j.Logger;然后使用Logger.getLogger()方法...

    log4j多文件输出打印

    本话题将深入探讨如何使用Log4j实现多文件输出打印,以及自定义日志的配置。 首先,我们要理解Log4j的基本工作原理。Log4j的核心组件包括Logger、Appender和Layout。Logger负责生成日志事件,Appender则负责接收...

    SSM框架log4j.properties日志打印必备包

    SSM框架log4j.properties日志打印必备包SSM框架log4j.properties日志打印必备包SSM框架log4j.properties日志打印必备包SSM框架log4j.properties日志打印必备包

    log4j依赖jar包

    例如,你可以设置一个ConsoleAppender将日志打印到控制台,或者设置FileAppender将日志写入文件。同时,还可以利用PatternLayout或JSONLayout定制日志输出的格式。 为了保证最佳性能和安全性,开发者应时刻关注Log4...

    日志打印文件log4j

    日志打印文件log4j日志打印文件log4j日志打印文件log4j日志打印文件log4j日志打印文件log4j

    log4j(二):动态配置日志输出路径

    在Web应用中,如使用的是Servlet环境,可以通过在`web.xml`中配置`ContextLoaderListener`来加载Log4j配置,同时,我们还可以创建一个Servlet,当接收到特定请求时,更新Log4j配置。 ```xml <!-- web.xml 示例 --> ...

    log4j日志打印demo

    **正文** 日志系统在软件开发中扮演着至关重要的角色,它可以帮助开发者追踪程序...在"log4j日志打印demo"中,你将学习到如何设置Log4j以实现控制台和SD卡(针对Android)的日志输出,从而在实际开发中更加得心应手。

    java关于log4j打印日志demo

    本示例将详细介绍如何在Java项目中使用Log4j进行日志打印。 首先,Log4j的核心组件包括配置文件(通常为`log4j.properties`或`log4j.xml`)、Logger、Appender和Layout。配置文件定义了日志信息的输出方式、目的地...

    log4j 日志打印jar

    《深入理解Log4j:构建高效...以上就是关于Log4j日志打印的全面解析,希望能对你自定义的日志记录工具提供有价值的参考和启示。在实际使用中,不断学习和实践,才能更好地发挥Log4j的优势,提升日志记录的质量和效率。

    配置好log4j的eclipse简单工程,每天输出到一个日志文件中,该文件名为:“XXX_年月日时分.log”的形式

    Log4j的优势在于其可配置性,允许开发者根据需求调整日志的输出方式和存储位置。 2. **Eclipse工程配置**: 在Eclipse中,我们需要添加Log4j的依赖库。这通常通过添加JAR文件到项目的类路径或者依赖管理(如Maven...

    log4j jar包 日志包

    在使用"apache-log4j-2.11.0-bin"压缩包时,你需要解压并配置相应的log4j2.xml或log4j2.json文件,然后在项目中引入Log4j的jar包,即可开始使用这个强大的日志系统。正确配置和使用Log4j,可以帮助开发者提高问题...

    Log4j采用分模块输出不同日志文件的配置

    Log4j采用分模块输出不同日志文件的配置

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

    当我们遇到“无法打出log4j日志的问题”,这通常是由于配置、环境或代码实现中的某些错误导致的。这篇长文将深入探讨如何排查和解决这类问题。 首先,我们要理解Log4j的基本工作原理。Log4j通过配置文件(通常是log...

    Log4j日志配置说明,Log4j日志配置说明

    ### Log4j日志配置详解 #### 一、概述 Log4j 是一个基于 Java 的开源日志记录框架,由 Apache 软件基金会维护。它允许开发人员根据等级记录日志信息,使得用户能够控制日志信息的记录级别及去向。本文将通过一份...

Global site tag (gtag.js) - Google Analytics