当前位置:   article > 正文

使用Log4j进行日志打印流程_log4j 1.2.17打印日志

log4j 1.2.17打印日志

当我们需要在项目中打印日志并输出到指定的日志文件中时,我们需要进行配置log4j进行日志的打印。

步骤如下:

1、引入约束

   如果是动态web工程需要引入如下两个jar包:

    commons-logging-版本号.jar

  log4j-版本号.jar

    如果是maven工程 需要在pom中引入如下两个约束:

  1. <dependency>
  2. <groupId>log4j</groupId>
  3. <artifactId>log4j</artifactId>
  4. <version>1.2.17</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>commons-logging</groupId>
  8. <artifactId>commons-logging</artifactId>
  9. <version>1.1.1</version>
  10. </dependency>
2、log4j.properties配置文件的加载

当在项目中引入了如上两个约束后,项目启动后,会在开发路径下:resources下,项目部署后classes路径下自动寻找配置文件log4j.properties

如果想要自定义log4j.properties配置文件位置,需要在web.xml中添加log4j的监听。

  1. <!-- 配置log4j配置文件路径 -->
  2. <context-param>
  3. <param-name>log4jConfigLocation</param-name>
  4. <param-value>classpath:log4j.properties</param-value>
  5. </context-param>
  6. <!-- 60s 检测日志配置 文件变化 -->
  7. <context-param>
  8. <param-name>log4jRefreshInterval</param-name>
  9. <param-value>60000</param-value>
  10. </context-param>
  11. <!-- 配置Log4j监听器 -->
  12. <listener>
  13. <listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
  14. </listener>
3、log4j文件的编写

demo:

  1. log4j.rootLogger=error,Console
  2. log4j.logger.org.hibernate.type.descriptor.sql.BasicBinder=TRACE
  3. #log4j.logger.org.hibernate.type.descriptor.sql.BasicExtractor=TRACE
  4. log4j.logger.org.hibernate.tool.hbm2ddl=DEBUG
  5. #log4j.logger.org.hibernate.SQL=DEBUG
  6. log4j.appender.Console=org.apache.log4j.ConsoleAppender
  7. log4j.appender.Console.Target=System.out
  8. log4j.appender.Console.layout=org.apache.log4j.PatternLayout
  9. log4j.appender.Console.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n
  10. log4j.appender.OneFile=org.apache.log4j.DailyRollingFileAppender
  11. log4j.appender.OneFile.File=../logs/AI_COMM_MANAGER.log
  12. log4j.appender.OneFile.DatePattern = '.'yyyy-MM-dd
  13. log4j.appender.OneFile.Threshold=ALL
  14. log4j.appender.OneFile.layout=org.apache.log4j.PatternLayout
  15. log4j.appender.OneFile.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n
  16. log4j.logger.MyScan=DEBUG,scan
  17. log4j.additivity.MyScan=false
  18. log4j.appender.scan=org.apache.log4j.DailyRollingFileAppender
  19. log4j.appender.scan.File=../logs/scan.log
  20. log4j.appender.scan.DatePattern = '.'yyyy-MM-dd
  21. log4j.appender.scan.Threshold=ALL
  22. log4j.appender.scan.layout=org.apache.log4j.PatternLayout
  23. log4j.appender.scan.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n
  24. log4j.logger.Count=DEBUG,count
  25. log4j.additivity.Count=false
  26. log4j.appender.count=org.apache.log4j.RollingFileAppender
  27. log4j.appender.count.File=../logs/count.log
  28. log4j.appender.FILE.MaxFileSize=10MB
  29. log4j.appender.FILE.Append = true
  30. log4j.appender.count.Threshold=ALL
  31. log4j.appender.count.layout=org.apache.log4j.PatternLayout
  32. log4j.appender.count.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n

rootLogger参数配置的后面两个表示输出位置

也可以通过log4j.logger.自定义log名字=日志等级,名字

在代码里面通过名字获取指定的log对象,打印到自定义的日志文件中

4、Log在java代码中的使用
private final static Log logger = LogFactory.getLog("Http");

注意导包一定是 apache.commons.logging下的包

备注:打印日志的工具类 还有logback等,很多,很杂,但是apache的log很经典,很好用

也可以参考 https://blog.csdn.net/qq_37733625/article/details/79046227


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/运维做开发/article/detail/963203
推荐阅读
相关标签
  

闽ICP备14008679号