`
这些年
  • 浏览: 402302 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

log4j 转出日志到不同的地方(转)

 
阅读更多

配置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  

 

分享到:
评论

相关推荐

    apache log4j 日志系统实现原理.doc

    Apache Log4j 是一个广泛使用的Java日志框架,它的核心功能是记录应用程序中的事件和错误信息,便于跟踪问题、分析性能以及调试。Log4j 提供了一种灵活、高效的日志记录机制,允许开发者定制日志输出的方式、位置和...

    log4j日志记录

    Log4j作为一款强大的日志工具,因其易用性和灵活性而受到广泛欢迎。 Log4j支持多种输出方式,包括控制台、文件、邮件、数据库等,并且可以通过配置文件灵活调整日志级别、格式以及输出目标。此外,Log4j还支持多...

    log4j帮助文档与使用手册

    例如,`log4j.rootCategory=INFO, stdout, R`这条配置意味着所有日志信息至少在INFO级别会被输出到名为stdout(控制台)和R(滚动文件)的两个目的地。接下来的几行分别定义了stdout和R这两个appender的类型、布局和...

    Log4j的使用方法.doc

    - `commons-logging.jar`:Apache Commons Logging库,提供了一个API来抽象出不同的日志框架,包括Log4j。 - `log4j.jar`:Log4j的核心库,包含了Log4j的实现。 2. **主要组件**: - **Logger**:负责生成日志...

    Nodejs Express 通过log4js写日志到Logstash(ELK)

    在本文中,我们将探讨如何使用Node.js的Express框架结合log4js库来将日志信息发送到Logstash,进而整合到ELK(Elasticsearch、Logstash、Kibana)堆栈中。ELK堆栈是一种流行的数据收集、处理和可视化解决方案,常...

    pinyin4j-2.5.0.zip

    3. CHANGELOG.txt:变更日志记录了自上一个版本以来的更新内容,包括新增功能、修复的bug以及改进的地方。开发者可以通过它了解新版本的改进,决定是否升级到最新版本。 4. src目录:包含了库的源代码,开发者可以...

    DWR需要的包

    DWR使用这个库来抽象出日志实现,便于切换不同的日志系统。 通过这些库,DWR能够构建起服务器与客户端之间的桥梁,使得开发者可以轻松地在JavaScript中调用Java方法,同时处理服务器端的数据和逻辑。这些依赖库共同...

    最新commons-beanutils-1.9.3及logging带源码

    它的主要作用是允许开发者在不改变代码的情况下,自由地切换底层的日志实现,如log4j、java.util.logging或logback。这样做的好处在于,项目可以在开发阶段使用一种日志框架,在生产环境中根据实际需求更换为另一种...

    Java基础学习17.pdf

    日志框架(如log4j和log4j2)允许我们设置不同的级别(如TRACE、DEBUG、INFO、WARN、ERROR),控制输出位置,格式化输出,并通过配置文件进行定制。 增强型for循环(JDK 1.5引入): 增强型for循环,也称为foreach...

    JSP论文格式化系统_——后台模块的设计与实现(源代码+论文).zip

    6. **日志记录**:为了便于问题排查和系统维护,后台需要记录用户操作日志,包括登录、修改、删除等行为,这通常使用Log4j或SLF4J等日志框架实现。 7. **错误处理与通知**:当发生错误时,后台应能捕获异常,生成...

    java做的公交系统

    同时,日志记录也是必不可少的,Java的Log4j或SLF4J等日志框架可以帮助记录程序运行过程中的信息,便于后期问题排查和性能分析。 七、可扩展性与模块化设计 为了适应未来功能的增加或系统的扩展,公交系统通常会...

    Java开发手册 免费

    在日志规约中,要求使用日志记录框架(如Log4j、SLF4J等)记录程序运行过程中的关键信息,便于问题定位和性能监控。 MySQL规约部分则对数据库的设计、查询优化、ORM使用等方面给出了详细规范,比如要求合理建立索引...

    99-Apache InLong 的 SPI 扩展实践.pdf

    - **日志框架**:SLF4J 使用 SPI 来加载不同的日志实现,如 Logback 或 Log4j。 - **Spring 类型转换**:Spring 使用 SPI 实现类型转换的扩展性,例如 Converter SPI 和 Formatter SPI。 ##### SPI 改造实践 为了...

    java异常机制研究

    常用的日志框架如 Log4j 或 SLF4J 可以帮助我们轻松记录异常。 #### 三、异常处理在项目中的实践 在实际开发中,异常处理是一项非常重要的任务,它直接影响着应用程序的稳定性和用户体验。 1. **异常处理策略**:...

    mybatis深入浅出

    例如,PageHelper分页插件可以方便地实现数据库的分页查询,而Log4j插件可以帮助我们记录SQL执行日志。 总之,《MyBatis 深入浅出》将带你逐步探索MyBatis的每一个角落,从基本的配置到高级的特性,让你能够熟练地...

    java 编程规范

    - 使用日志框架如Log4j、SLF4J记录程序运行状态。 - 分级日志,如DEBUG、INFO、WARN和ERROR。 13. 测试: - 编写单元测试,确保代码功能正确。 - 使用Mockito等工具进行隔离测试。 14. 性能优化: - 避免不必...

    Java实现图书馆管理系统源码.zip

    10. **日志记录**:通过Log4j或SLF4J等日志库记录系统运行过程中的信息,便于调试和问题排查。 11. **版本控制**:项目可能使用Git等版本控制系统进行代码管理和协作。 12. **构建工具**:如Maven或Gradle用于项目...

    好的程序结构是这样的

    相比使用`System.out.println()`打印输出,采用`log4j`等专业日志框架可以提供更丰富的信息,且便于后期的日志管理和分析。更重要的是,日志框架允许在不修改代码的情况下调整日志级别,适应不同的部署环境。 九、...

    java面试题和基础知识汇总超详细

    `log4j`的日志级别包括`OFF`、`FATAL`、`ERROR`、`WARN`、`INFO`、`DEBUG`、`ALL`。这些级别定义了日志记录的严重程度,便于开发者和运维人员根据实际需求调整日志输出的详细程度。 #### JavaBean特点 JavaBean是...

    JS超级名著《Essentials of Javascript》

    Log4javascript可以配置不同的日志级别,并且支持将日志消息发送到不同的目的地,如控制台、文件或远程服务器。 ### Medireview **Medireview**可能是指某个使用JavaScript开发的医疗信息系统或平台。虽然具体细节...

Global site tag (gtag.js) - Google Analytics