spring 设置日记

打印 上一主题 下一主题

主题 1707|帖子 1707|积分 5121

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
在 Spring Boot 中,日记配置是开发和生产环境的关键部分。以下是 Spring Boot 日记配置的完备指南,涵盖默认配置、自定义配置、日记框架切换(Logback/Log4j2)及高级用法。

1. 默认日记配置

Spring Boot 默认利用 Logback 作为日记框架,并自动配置以下举动:
控制台输出:日记级别为 INFO 及以上。
日记文件:默认不生成文件(需手动配置)。
彩色输出:终端支持时启用彩色日记。

2. 基础配置(application.properties/application.yml)

(1)设置日记级别

  1. # 设置全局日志级别
  2. logging.level.root=INFO
  3. # 设置特定包或类的日志级别
  4. logging.level.org.springframework=WARN
  5. logging.level.com.example.service=DEBUG
复制代码
(2)输出到文件

  1. # 输出到指定文件(默认路径为项目根目录)
  2. logging.file.name=logs/app.log
  3. # 或指定目录(自动生成 spring.log)
  4. logging.file.path=logs/
复制代码
(3)日记格式

  1. # 控制台日志格式
  2. logging.pattern.console=%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n
  3. # 文件日志格式
  4. logging.pattern.file=%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n
复制代码

3. 高级配置(Logback 扩展)

Spring Boot 支持通过 logback-spring.xml 自定义配置(优先于默认配置)。
(1)创建 logback-spring.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <configuration>
  3.     <!-- 控制台输出 -->
  4.     <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
  5.         <encoder>
  6.             <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %highlight(%-5level) %cyan(%logger{36}) - %msg%n</pattern>
  7.         </encoder>
  8.     </appender>
  9.     <!-- 文件输出(按天滚动) -->
  10.     <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
  11.         <file>logs/app.log</file>
  12.         <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
  13.             <fileNamePattern>logs/app-%d{yyyy-MM-dd}.log</fileNamePattern>
  14.             <maxHistory>30</maxHistory> <!-- 保留30天日志 -->
  15.         </rollingPolicy>
  16.         <encoder>
  17.             <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</pattern>
  18.         </encoder>
  19.     </appender>
  20.     <!-- 日志级别及输出 -->
  21.     <root level="INFO">
  22.         <appender-ref ref="CONSOLE"/>
  23.         <appender-ref ref="FILE"/>
  24.     </root>
  25.     <!-- 环境敏感配置(如开发环境启用 DEBUG) -->
  26.     <springProfile name="dev">
  27.         <logger name="com.example" level="DEBUG"/>
  28.     </springProfile>
  29. </configuration>
复制代码
(2)启用 Profile 特定配置

在 application.properties 中激活 Profile:
  1. spring.profiles.active=dev
复制代码

4. 切换至 Log4j2

(1)排除 Logback,引入 Log4j2

  1. <!-- Maven 配置 -->
  2. <dependency>
  3.     <groupId>org.springframework.boot</groupId>
  4.     <artifactId>spring-boot-starter-web</artifactId>
  5.     <exclusions>
  6.         <exclusion>
  7.             <groupId>org.springframework.boot</groupId>
  8.             <artifactId>spring-boot-starter-logging</artifactId>
  9.         </exclusion>
  10.     </exclusions>
  11. </dependency>
  12. <dependency>
  13.     <groupId>org.springframework.boot</groupId>
  14.     <artifactId>spring-boot-starter-log4j2</artifactId>
  15. </dependency>
复制代码
(2)配置 log4j2-spring.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <Configuration status="WARN">
  3.     <Appenders>
  4.         <Console name="Console" target="SYSTEM_OUT">
  5.             <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n"/>
  6.         </Console>
  7.         <RollingFile name="File" fileName="logs/app.log"
  8.                      filePattern="logs/app-%d{yyyy-MM-dd}.log">
  9.             <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5level %logger{36} - %msg%n"/>
  10.             <Policies>
  11.                 <TimeBasedTriggeringPolicy interval="1" modulate="true"/>
  12.             </Policies>
  13.             <DefaultRolloverStrategy max="30"/>
  14.         </RollingFile>
  15.     </Appenders>
  16.     <Loggers>
  17.         <Root level="INFO">
  18.             <AppenderRef ref="Console"/>
  19.             <AppenderRef ref="File"/>
  20.         </Root>
  21.         <Logger name="com.example" level="DEBUG"/>
  22.     </Loggers>
  23. </Configuration>
复制代码

5. 日记配置最佳实践

环境区分:通过 Profile 为开发、生产环境配置不同日记级别。
日记滚动:按时间或巨细滚动日记文件,制止单个文件过大。
敏感信息过滤:在日记模式中排除敏感数据(如暗码)。
异步日记:在高并发场景下利用异步 Appender 提升性能(Logback/Log4j2 均支持)。
  1. <!-- Logback 异步日志示例 -->
  2. <appender name="ASYNC_FILE" class="ch.qos.logback.classic.AsyncAppender">
  3.     <appender-ref ref="FILE"/>
  4. </appender>
复制代码

6. 常用下令和调试

动态调解日记级别(无需重启):
  1. curl -X POST http://localhost:8080/actuator/loggers/com.example -H 'Content-Type: application/json' -d '{"configuredLevel":"DEBUG"}'
复制代码
查看日记端点(需 spring-boot-actuator):
  1. management.endpoints.web.exposure.include=loggers
复制代码

通过以上配置,你可以灵活控制 Spring Boot 应用的日记举动,适应不同场景需求。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

种地

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表