网站首页 > 开源技术 正文
tinylog(https://tinylog.org/v2/),与其他各种tiny开头的东西一样,是一个轻量级的开源日志解决方案。它本身只包含两个JAR文件(一个用于API,另一个用于实现),没有任何外部依赖关系。两个JAR文件的总大小只有178KB。
虽然是一个轻量级级别方案,但我们常用的基本日志管理功能都非常完备,它拥有与其他热门日志框架类似的API设计、多种可配置的日志输出选项、性能方面也是非常的出彩(这是官方给出的Benchmark(
https://tinylog.org/v2/benchmark/))。
今天我们就来学习一下,如何在Spring Boot中使用tinylog记录日志。
整合tinylog
通过之前Spring Boot 2.x基础教程:使用log4j2记录日志 (
https://blog.didispace.com/spring-boot-learning-2-8-2)一文的学习,回忆一下,整合其他日志框架,是不是可以总结为这样几步:
- 排除Spring Boot默认日志框架依赖
- 引入要使用的日志框架依赖
- 加入新日志框架的配置文件
好了,我们就按这个步骤来实战一下:
第一步:排除Spring Boot默认日志框架依赖
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
第二步:引入tinylog的依赖
<properties>
<tinylog.version>2.4.1</tinylog.version>
</properties>
<dependencies>
<dependency>
<groupId>org.tinylog</groupId>
<artifactId>tinylog-api</artifactId>
<version>${tinylog.version}</version>
</dependency>
<dependency>
<groupId>org.tinylog</groupId>
<artifactId>tinylog-impl</artifactId>
<version>${tinylog.version}</version>
</dependency>
<dependency>
<groupId>org.tinylog</groupId>
<artifactId>slf4j-tinylog</artifactId>
<version>${tinylog.version}</version>
</dependency>
<dependency>
<groupId>org.tinylog</groupId>
<artifactId>jcl-tinylog</artifactId>
<version>${tinylog.version}</version>
</dependency>
<dependency>
<groupId>org.tinylog</groupId>
<artifactId>log4j1.2-api</artifactId>
<version>${tinylog.version}</version>
</dependency>
</dependencies>
测试与验证
到这里,基本整合已经完成了。我们不着急去对tinylog做详细配置,先验证下到这里是否都已经正确。跟之前的日志整合例子一样,写个主类打印下各个级别的日志。
@Slf4j
@SpringBootApplication
public class Chapter83Application {
public static void main(String[] args) {
SpringApplication.run(Chapter83Application.class, args);
log.error("Hello World");
log.warn("Hello World");
log.info("Hello World");
log.debug("Hello World");
log.trace("Hello World");
}
}
这里用了lombok的@Slf4j,如果还不了解的建议读一下这篇:Lombok:让JAVA代码更优雅(
https://blog.didispace.com/java-lombok-1/)
运行一下,从控制台可以看到输出内容如下:
通过debug,我们可以看到此时的log已经是TinylogLogger了
第三步:加入tinylog的配置文件
通过上一步,我们虽然已经完成了整合,但是上面的格式,是你想要的吗?加入配置调整一下!
在resources目录下创建文件:tinylog.properties,加入下面的配置:
writer=console
writer.format={date: HH:mm:ss.SSS} {level}: {message}
重新运行测试,控制台输出是不是好看一些了
更多配置,比如:文件输出、级别控制等这里就不详细说了,大家可以查看官方文档(
https://tinylog.org/v2/configuration/),基本上与其他框架都是类似的,很容易配置。
好了,今天的学习就到这里!如果您学习过程中遇到困难,可以加入我们超高质量的Spring技术交流群 ,参与交流与讨论,更好的学习与进步!
代码示例
本文的完整工程可以查看下面仓库中2.x目录下的chapter8-3工程:
- Github:https://github.com/dyc87112/SpringBoot-Learning/
- Gitee:https://gitee.com/didispace/SpringBoot-Learning/
如果您觉得本文不错,欢迎Star支持,您的关注是我坚持的动力!
猜你喜欢
- 2025-05-02 GrayLog开源日志管理平台技术文章合集【共58篇】
- 2025-05-02 AI大模型 MiniMax 基于 Apache Doris 的日志系统,PB 级秒级查询响应
- 2025-05-02 互联网大厂后端必看!手把手教你替换 Spring Boot 中的日志框架
- 2025-05-02 一共81个,开源大数据处理工具汇总(下),包括日志收集系统
- 2025-05-02 性能优越的轻量级日志收集工具,微软、亚马逊都在用
- 2025-05-02 安全技术研究-日志注入攻击(日志注入防护)
- 2025-05-02 【运维必看】从 CI/CD 到监控,一款开源平台搞定所有运维痛点!
- 2025-05-02 lnav:基于 Linux 的高级控制台日志文件查看器
- 2025-05-02 开源工具!在Ubuntu上配置日志查询系统
- 2025-05-02 基于 Delta lake、Hudi 格式的湖仓一体方案
你 发表评论:
欢迎- 最近发表
-
- 10款鲜为人知的PHP框架(10款鲜为人知的php框架代码)
- 3分钟搞懂反弹shell(反弹shell的常用命令)
- 计算机专业必须掌握的脚本开发语言—shell
- shell 基本语法(shell基本语法set)
- 学习Shell 教程(shell编程学习)
- 一个有意思的PHP Webshell,利用伪协议执行代码
- Linux入门-shell编程-适合小白(linux shell编程是什么)
- GrayLog开源日志管理平台技术文章合集【共58篇】
- AI大模型 MiniMax 基于 Apache Doris 的日志系统,PB 级秒级查询响应
- 互联网大厂后端必看!手把手教你替换 Spring Boot 中的日志框架
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)