欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-07-12 19:09:01
...

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

 

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

 

配置log4j.properties文件如下:

Java代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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代码  Log4j 把不同包的日志打印到不同位置
            
    
    博客分类: 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