zoukankan      html  css  js  c++  java
  • Log4j 把不同包的日志打印到不同位置

    如果需要将不同的日志打印到不同的地方,则需要定义不同的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  
  • 相关阅读:
    SQL0668N Operation not allowed for reason code "3" on table "TEST". SQLSTATE=57016
    为何存在requests库,pycharm依然报错解决方法 --转载
    vmware12启动centos6.8报错ACPI:memory_hp:Memory online failed
    deepin升级之后打不开控制中心
    ubuntu中接一个摄像头会出现两个/dev/video
    VMware16中Ubuntu不显示共享文件夹的解决办法
    opencv获取当前帧数据问题
    libusb函数
    设置ubuntu、deppin(等linux系统)和window双系统启动引导顺序
    window和ubuntu双系统删除"ubuntu"
  • 原文地址:https://www.cnblogs.com/onetwo/p/7120050.html
Copyright © 2011-2022 走看看