资讯专栏INFORMATION COLUMN

SpringBoot进阶教程 | 第二篇:日志组件logback实现日志分级打印

yy736044583 / 2239人阅读

摘要:而的日志文件在由指定。创建启动类控制台打印开源项目本地日志打印效果这里因为配置中将不同级别的日志设置了在不同文件中打印,这样很大程度上方便项目出问题查找问题。

你是否因为项目出现问题,查找日志文件定位错误花费N多时间,是否为此苦不堪言,没关系!现在通过这篇文章,将彻底解决你的烦恼,这篇文篇介绍,如何通过logback配置文件将日志进行分级打印,一个配置文件彻底搞定日志查找得烦恼。

准备工作

环境:

</>复制代码

  1. windows
  2. jdk 8
  3. maven 3.0
  4. IDEA
构建工程

</>复制代码

  1. 4.0.0
  2. cn.zhangbox
  3. spring-boot-study
  4. 1.0-SNAPSHOT
  5. cn.zhangbox
  6. spring-boot-log
  7. 0.0.1-SNAPSHOT
  8. jar
  9. spring-boot-logging
  10. Demo project for Spring Boot
  11. UTF-8
  12. UTF-8
  13. 1.8
  14. org.springframework.boot
  15. spring-boot-starter-web
  16. org.springframework.boot
  17. spring-boot-starter-test
  18. test
  19. org.springframework.boot
  20. spring-boot-maven-plugin
修改YML配置

</>复制代码

  1. #选择哪一个环境的配置
  2. #这里可以在每个环境配置redis,数据库(mysql),消息(kafka)等相关的组件的配置
  3. spring:
  4. profiles:
  5. active: dev
  6. #文档块区分为三个---
  7. ---
  8. server:
  9. port: 8081
  10. spring:
  11. profiles: dev
  12. #日志
  13. logging:
  14. #日志配置文件位置
  15. config: classpath:log/logback.xml
  16. #日志打印位置,这里是默认在项目根路径下
  17. path: log/spring-boot-log
  18. #文档块区分为三个---
  19. ---
  20. server:
  21. port: 8082
  22. spring:
  23. profiles: test
  24. #日志
  25. logging:
  26. #日志配置文件位置
  27. config: classpath:log/logback.xml
  28. #日志打印位置,这里是默认在项目根路径下
  29. path: usr/spring-boot/log/spring-boot-log
  30. #文档块区分为三个---
  31. ---
  32. server:
  33. port: 8083
  34. spring:
  35. profiles: prod
  36. #日志
  37. logging:
  38. #日志配置文件位置
  39. config: classpath:log/logback.xml
  40. #日志打印位置,这里是默认在项目根路径下
  41. path: usr/spring-boot/log/spring-boot-log
创建日志配置文件

在工程resources文件夹下新建文件夹log,并在该文件夹下创建logback.xml文件,加入以下配置:

</>复制代码

  1. ${CONSOLE_LOG_PATTERN}
  2. UTF-8
  3. debug
  4. ${LOG_PATH}/log_debug.log
  5. %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
  6. UTF-8
  7. ${LOG_PATH}/debug/log-debug-%d{yyyy-MM-dd}.%i.log
  8. 500MB
  9. 30
  10. debug
  11. ACCEPT
  12. DENY
  13. ${LOG_PATH}/log_info.log
  14. %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
  15. UTF-8
  16. ${LOG_PATH}/info/log-info-%d{yyyy-MM-dd}.%i.log
  17. 500MB
  18. 30
  19. info
  20. ACCEPT
  21. DENY
  22. ${LOG_PATH}/log_warn.log
  23. %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
  24. UTF-8
  25. ${LOG_PATH}/warn/log-warn-%d{yyyy-MM-dd}.%i.log
  26. 500MB
  27. 30
  28. warn
  29. ACCEPT
  30. DENY
  31. ${LOG_PATH}/log_error.log
  32. %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
  33. UTF-8
  34. ${LOG_PATH}/error/log-error-%d{yyyy-MM-dd}.%i.log
  35. 500MB
  36. 30
  37. error
  38. ACCEPT
  39. DENY

注意loback配置文件中

</>复制代码

name的属性值一定要是当前工程的java代码的完整目录,因为mybatis打印的日志级别是debug级别的,因此需要配置debug级别日志扫描的目录。

创建启动类

</>复制代码

  1. @SpringBootApplication
  2. public class SpringBootConfigApplication {
  3. public static void main(String[] args) {
  4. SpringApplication.run(SpringBootConfigApplication.class, args);
  5. }
  6. }
控制台打印

</>复制代码

  1. . ____ _ __ _ _
  2. / / ___"_ __ _ _(_)_ __ __ _
  3. ( ( )\___ | "_ | "_| | "_ / _` |
  4. / ___)| |_)| | | | | || (_| | ) ) ) )
  5. " |____| .__|_| |_|_| |_\__, | / / / /
  6. =========|_|==============|___/=/_/_/_/
  7. :: Spring Boot :: (v1.5.3.RELEASE)
  8. 2018-07-05 15:05:13.680 INFO 15060 --- [ main] c.z.s.SpringBootLoggingApplication : Starting SpringBootLoggingApplication on MS-20180428GSYE with PID 15060 (started by Administrator in D:开源项目spring-boot-study)
  9. 2018-07-05 15:05:13.685 DEBUG 15060 --- [ main] c.z.s.SpringBootLoggingApplication : Running with Spring Boot v1.5.3.RELEASE, Spring v4.3.8.RELEASE
  10. 2018-07-05 15:05:13.686 INFO 15060 --- [ main] c.z.s.SpringBootLoggingApplication : The following profiles are active: dev
  11. 2018-07-05 15:05:13.766 INFO 15060 --- [ main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@79d94571: startup date [Thu Jul 05 15:05:13 GMT+08:00 2018]; root of context hierarchy
  12. 2018-07-05 15:05:14.223 INFO 15060 --- [kground-preinit] o.h.validator.internal.util.Version : HV000001: Hibernate Validator 5.3.5.Final
  13. 2018-07-05 15:05:15.550 INFO 15060 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8081 (http)
  14. 2018-07-05 15:05:15.563 INFO 15060 --- [ main] o.apache.catalina.core.StandardService : Starting service Tomcat
  15. 2018-07-05 15:05:15.565 INFO 15060 --- [ main] org.apache.catalina.core.StandardEngine : Starting Servlet Engine: Apache Tomcat/8.5.14
  16. 2018-07-05 15:05:15.703 INFO 15060 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext
  17. 2018-07-05 15:05:15.704 INFO 15060 --- [ost-startStop-1] o.s.web.context.ContextLoader : Root WebApplicationContext: initialization completed in 1938 ms
  18. 2018-07-05 15:05:15.869 INFO 15060 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean : Mapping servlet: "dispatcherServlet" to [/]
  19. 2018-07-05 15:05:15.876 INFO 15060 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: "characterEncodingFilter" to: [/*]
  20. 2018-07-05 15:05:15.877 INFO 15060 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: "hiddenHttpMethodFilter" to: [/*]
  21. 2018-07-05 15:05:15.877 INFO 15060 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: "httpPutFormContentFilter" to: [/*]
  22. 2018-07-05 15:05:15.877 INFO 15060 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: "requestContextFilter" to: [/*]
  23. 2018-07-05 15:05:16.219 INFO 15060 --- [ main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@79d94571: startup date [Thu Jul 05 15:05:13 GMT+08:00 2018]; root of context hierarchy
  24. 2018-07-05 15:05:16.298 INFO 15060 --- [ main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
  25. 2018-07-05 15:05:16.299 INFO 15060 --- [ main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)
  26. 2018-07-05 15:05:16.328 INFO 15060 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
  27. 2018-07-05 15:05:16.328 INFO 15060 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
  28. 2018-07-05 15:05:16.369 INFO 15060 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
  29. 2018-07-05 15:05:16.616 INFO 15060 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Registering beans for JMX exposure on startup
  30. 2018-07-05 15:05:16.636 INFO 15060 --- [ main] o.a.coyote.http11.Http11NioProtocol : Initializing ProtocolHandler ["http-nio-8081"]
  31. 2018-07-05 15:05:16.645 INFO 15060 --- [ main] o.a.coyote.http11.Http11NioProtocol : Starting ProtocolHandler ["http-nio-8081"]
  32. 2018-07-05 15:05:16.659 INFO 15060 --- [ main] o.a.tomcat.util.net.NioSelectorPool : Using a shared selector for servlet write/read
  33. 2018-07-05 15:05:16.679 INFO 15060 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8081 (http)
  34. 2018-07-05 15:05:16.685 INFO 15060 --- [ main] c.z.s.SpringBootLoggingApplication : Started SpringBootLoggingApplication in 4.291 seconds (JVM running for 5.767)
本地日志打印效果

这里因为logback配置中将不同级别的日志设置了在不同文件中打印,这样很大程度上方便项目出问题查找问题。

源码地址

Spring Boot日志组件logback实现日志分级打印源码

欢迎关注我的微信公众号获取更多更全的学习资源,视频资料,技术干货!

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/71474.html

相关文章

  • SpringCloud核心教程 | 第三篇:服务注册与发现 Eureka篇

    摘要:下一篇介绍基于的服务注册与调用。服务提供者工程配置这里服务提供者是使用之前进阶教程第三篇整合连接池以及监控改造而来,这里一样的部分就不再重复说明,下面将说明新增的部分。 Spring Cloud简介 Spring Cloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中涉及的配置管理、服务发现、断路器、智能路由、微代理、控制总线、全局锁、决策竞选、分...

    scq000 评论0 收藏0
  • 强推!大牛程序员必备的Java日志框架,性能无敌

    摘要:本文要来分享给大家程序员最常用的日志框架组件。没有基础的同学也不要着急,这套教程覆盖了目前所有的日志框架,只要你学,就一定用得到,先收藏,以备不时之需。 作为一名Java程序员,我们开发了很多Java应用程序,包括桌面应用、WEB应用以及移动应用。然而日志系统是一个成熟Java应用所必不可少的。在开发和调试阶段,日志可以帮...

    zebrayoung 评论0 收藏0
  • springboot超级详细的日志配置(基于logback)

    摘要:默认情况下将级别的日志输出到控制台中,不会写到日志文件,且不能进行复杂配置。节点用于定义变量,方便使用。 showImg(https://raw.githubusercontent.com/FleyX/files/master/blogImg/20190320135049.png); 前言   java web 下有好几种日志框架,比如:logback,log4j,log4j2(slj...

    meislzhua 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<