Springboot 日志

1、日志框架

开发一个大型系统;
1、System.out.println(“”);将关键数据打印在控制台;去掉?写在一个文件?
2、框架来记录系统的一些运行时信息;日志框架;zhanglogging.jar
3、高大上的功能?异步模式?自动归档?xxx?zhanglogginglog-good.jar
4、将以前的框架卸下来,换上新的框架,重新修改之前的相关的API,zhanglogging-prefect.jar
5、JDBC数据库驱动驱动; 写一个统一的接口层;日志门面(日志的一个抽象层);logging-bstract.jar;给项目中导入具体日志实现就行了。
市面上的日志框架
JUL、JCL、Jboss-logging、logback、log4j、log4j2、slf4j……

日志门面(日志的抽象层)日志实现
JCL、SLF4j、Jboss-logginglog4j、log4j2、JUL、logback

SpringBoot:底层是Spring框架,Spring框架默认是JCL;
Spring选用SLF4j和Logback

2、SLF4j使用

1、日志格式

2021-06-26 === [http-nio-8081-exec-1] === INFO  === org.apache.tomcat.util.http.parser.Cookie === A cookie header was received [1622685400,1622686345,1622686741] that contained an invalid cookie. That cookie will be ignored.
 Note: further occurrences of this error will be logged at DEBUG level.
2021-06-26 === [http-nio-8081-exec-1] === INFO  === o.a.c.core.ContainerBase.[Tomcat].[localhost].[/] === Initializing Spring DispatcherServlet 'dispatcherServlet'
2021-06-26 === [http-nio-8081-exec-1] === INFO  === org.springframework.web.servlet.DispatcherServlet === Initializing Servlet 'dispatcherServlet'
2021-06-26 === [http-nio-8081-exec-1] === INFO  === org.springframework.web.servlet.DispatcherServlet === Completed initialization in 0 ms

时间日期:精确到毫秒,可以用于排序
日志级别 trace<debug<info<warn<error<fatal
默认级别为info,即默认打印info及其以上级别的日志
进程ID:分隔符:采用 — 来标识日志开始部分
线程名:方括号括起来(可能会截断控制台输出)
Logger名:通常使用源代码的类名
日志内容:我们输出的消息

2、日志输出

SpringBoot 默认为我们输出的日志级别为 INFO、WARN、ERROR,如需要输出更多日志的时候,可以通过以下方式开启

  • 命令模式配置: java -jar app.jar --debug=true , 这种命令会被 SpringBoot 解析,且优先级最高
  • 资源文件配置: application.properties 配置 debug=true 即可。该配置只对 嵌入式容器、Spring、Hibernate生效,我们自己的项目想要输出 DEBUG 需要额外配置(配置规则:logging.level.=)
  • logging.pattern.console: 定义输出到控制台的格式(不支持JDK Logger)
  • logging.pattern.file: 定义输出到文件的格式(不支持JDK Logger)
server.port=8081
#日志级别
logging.level.com.example=trace
#输出文件目录
logging.file.path=springbootLog
#控制台输出格式
logging.pattern.console=%d{yyyy-MM-dd} [%thread] %-5level %logger{50} - %msg%n
#文件输出格式
logging.pattern.file=%d{yyyy-MM-dd} === [%thread] === %-5level === %logger{50} === %msg%n

3、颜色编码

如果终端支持 ANSI,默认情况下会给日志上个色,提高可读性,可以在配置文件中设置 spring.output.ansi.enabled 来改变默认值
ALWAYS: 启用 ANSI 颜色的输出。
DETECT: 尝试检测 ANSI 着色功能是否可用。
NEVER: 禁用 ANSI 颜色的输出。

LevelColor
WARNYellow
FATAL、ERRORRed
INFO、DEBUG、TRACEGreen

4、文件保存

默认情况下,SpringBoot 仅将日志输出到控制台,不会写入到日志文件中去。如果除了控制台输出之外还想写日志文件,则需要在application.properties 设置logging.file 或 logging.path 属性。

logging.file: 将日志写入到指定的 文件 中,默认为相对路径,可以设置成绝对路径
logging.path: 将名为 spring.log 写入到指定的 文件夹 中,如(/var/log)
日志文件在达到 10MB 时进行切割,产生一个新的日志文件(如:spring.1.log、spring.2.log),新的日志依旧输出到 spring.log 中去,默认情况下会记录 ERROR、WARN、INFO 级别消息。

logging.file.max-size: 限制日志文件大小
logging.file.max-history: 限制日志保留天数

5、自定义日志配置

由于日志在 ApplicationContext 之前就初始化好了,所以 SpringBoot 为我们提供了 logging.config 属性,方便我们配置自定义日志文件。默认情况它会根据日志的依赖自动加载。

Logging SystemCustomization
JDK (Java Util Logging)logging.properties
Log4j2、ERRORlog4j2-spring.xml 或 log4j2.xml
Logbacklogback-spring.xml、logback-spring.groovy、logback.xml、logback.groovy

Logback扩展配置

该扩展配置仅适用 logback-spring.xml 或者设置 logging.config 属性的文件,因为 logback.xml 加载过早,因此无法获取 SpringBoot的一些扩展属性
使用扩展属性 springProfile 与 springProperty 让你的 logback-spring.xml 配置显得更有逼格,当别人还在苦苦挣扎弄logback-{profile}.xml的时候 你一个文件就搞定了…
springProfile
< springProfile> 标签使我们让配置文件更加灵活,它可以选择性的包含或排除部分配置。

<springProfile name="dev">
    <!-- 开发环境时激活 -->
</springProfile>
<springProfile name="dev,test">
    <!-- 开发,测试的时候激活-->
</springProfile>
<springProfile name="!prod">
    <!-- 当 "生产" 环境时,该配置不激活-->
</springProfile>
<!-- 开发环境日志级别为DEBUG/并且开发环境不写日志文件 -->
<springProfile name="dev">
    <root level="DEBUG">
        <appender-ref ref="STDOUT"/>
    </root>
</springProfile>
<!-- 测试环境日志级别为INFO/并且记录日志文件 -->
<springProfile name="test">
    <root level="INFO">
        <appender-ref ref="FILE"/>
        <appender-ref ref="STDOUT"/>
    </root>
</springProfile>

springProperty
< springProperty> 标签可以让我们在 Logback 中使用 Spring Environment 中的属性。如果想在logback-spring.xml中回读 application.properties 配置的值时,这是一个非常好的解决方案

<!-- 读取 spring.application.name 属性来生成日志文件名
    scope:作用域
    name:在 logback-spring.xml 使用的键
    source:application.properties 文件中的键
    defaultValue:默认值
 -->
<springProperty scope="context" name="logName" source="spring.application.name" defaultValue="myapp.log"/>
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>logs/${logName}.log</file>
</appender>

注解@Slf4j的使用

声明:如果不想每次都写private final Logger logger = LoggerFactory.getLogger(当前类名.class); 可以用注解@Slf4j;
1、导入依赖

<dependency>
   <groupId>org.projectlombok</groupId>
   <artifactId>lombok</artifactId>
    <version>1.16.16</version><!--版本号自己选一个就行-->
</dependency>

2、类上面添加@Sl4j注解,然后使用log打印日志;

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZSECode

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值