springboot2.x基础教程:日志配置

项目的开发过程中,开发人员对于日志一定不会陌生。日志能够记录程序运行的轨迹,输出软件运行中的关键信息,辅助我们排查与定位问题,优化程序运行性能,监控程序运行状态,不可不谓重要。
SpringBoot项目的spring-boot-starter默认引用spring-boot-starter-logging,其中底层采用logback日志框架,默认零配置即可使用日志记录功能。
在讲解springboot日志配置之前先简单谈谈JAVA日志有关的基础知识。

日志记录的时机#

  • 记录程序初始化有关启动的参数,判断程序的运行状态
  • 代码抛出异常,记录程序异常状态
  • 业务流程与预期结果不符,记录业务异常状态
  • 系统核心业务,核心权限操作。比如登录、付款等操作记录,通常还会入库分析。

Java日志框架#

对于日志框架,我们通常会看到log4j、logback等名词,也会遇到自己项目与第三方jar的日志库冲突问题。
初次接触这些,可能有种云雾缭绕不知所云的感觉,下面简单介绍下Java日志框架的关系。更具体的历史缘由,细节部分。网上有几篇文章介绍的很好,给大家附上自行阅读理解:

  1. 知乎上面有篇文章:java日志框架解析
  2. 博客上面有篇文章:Java常用日志框架介绍

看完以上文章简单的总结Java日志框架分为3类:

  • Java日志框架的具体的实现:log4j1.x、JUL(Java Util Log)、Logback、log4j2-core
  • Java日志框架的门面对象,只提供接口不提供具体实现:JCL(Commons Logging)、SLF4J(The Simple Logging Facade for Java)、log4j2-api
  • Java日志框架之间的适配器,为了让不同日志框架互相转换:jcl-over-slf4j、slf4j-jcl、log4j-over-slf4j、slf4j-log4j12等等
    图片来源网上

关于日志框架的最佳实践(来源参考链接,这里只是摘出):

  1. 总是使用Log Facade,而不是具体Log Implementation
  2. 只添加一个 Log Implementation依赖
  3. 具体的日志实现依赖应该设置为optional和使用runtime scope
  4. 如果有必要, 排除依赖的第三方库中的Log Impementation依赖
  5. 避免输出不必要的日志,跟不必要的日志字段如行号影响程序性能

SpringBoot日志配置#

日志依赖#

springboot默认使用SLF4J+Logback的组合记录日志,查看依赖可知,不用我们额外引入。

springboot日志配置#

Copy
logging: level: #包的日志级别 org.springframework.web: DEBUG #自定义log信息 config: classpath:config/logback-spring.xml pattern: #控制台的日志输出格式 console: '%d{yyyy/MM/dd-HH:mm:ss} [%thread] %-5level %logger- %msg%n' #文件的日志输出格式 file: '%d{yyyy/MM/dd-HH:mm} [%thread] %-5level %logger- %msg%n' file: #日志名称 name: app.log #存储的路径 path: /var/log/ #存储的最大值 max-size: 50MB #保存时间 max-history: 7

自定义的日志配置#

Copy
<?xml version="1.0" encoding="UTF-8"?> <configuration> <!--获取变量名中关于日志存储的路径与存储名称--> <springProperty scope="context" name="logPath" source="logging.file.path"/> <springProperty scope="context" name="logName" source="logging.file.name"/> <!--输出到控制台的appender--> <appender name="Console" class="ch.qos.logback.core.ConsoleAppender"> <layout class="ch.qos.logback.classic.PatternLayout"> <Pattern> %black(%d{ISO8601}) %highlight(%-5level) [%blue(%t)] %yellow(%C{1.}): %msg%n%throwable </Pattern> </layout> </appender> <!--输出到文件的appender--> <appender name="RollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender"> <file>${logPath}/${logName}</file> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <Pattern>%d %p %C{1.} [%t] %m%n</Pattern> </encoder> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- rollover daily and when the file reaches 10 MegaBytes --> <fileNamePattern>${LOGS}/archived/spring-boot-logger-%d{yyyy-MM-dd}.%i.log </fileNamePattern> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> </appender> <!--开发环境基本级别为DEBUG--> <springProfile name="dev"> <root level="DEBUG"> <appender-ref ref="Console"/> </root> </springProfile> <!--生产环境输入到文件中--> <springProfile name="prod"> <root level="INFO"> <appender-ref ref="RollingFile"/> </root> </springProfile> </configuration>

千里之行,始于足下。这里是SpringBoot教程系列第八篇,所有项目源码均可以在我的GitHub上面下载源码。

posted @   程序员众推  阅读(1278)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示
CONTENTS