Spring Boot的日志文件
日志的作用
- 最主要的用途就是排除和定位问题
- 记录用户的登入状态,方便分析用户是正常登入还是恶意破解用户,如果同一个用户一段时间内多次登入,就可以对该IP进行拉黑处理
- 记录系统的操作日志,方便数据恢复和定位操作人
- 记录程序的执行时间,方便为以后优化程序提供数据支持
如何使用日志
@Controller
@ResponseBody //表示返回的是数据而非页面
@RequestMapping("/art")
public class UserController {
//1. 得到日志对象
private static final Logger logger = LoggerFactory.getLogger(UserController.class);//参数表示该日志来自于哪个类
@RequestMapping("/hi")
public String sayHi() {
//2. 写日志
logger.trace("trace级别");
logger.debug("debug级别");
logger.info("info级别");
logger.warn("warn级别");
logger.error("error级别");
return "hi";
}
}
注意:在得到日志对象时要导入的是slf4j的包
输出如下:
我们发现trace和debug级别的日志没有打印,这是因为系统默认的日志级别是info。
系统内置的日志框架
Spring Boot能输出控制台日志信息,说明Spring Boot内置了日志框架。日志框架的设计模式是“门面模式”,类似于一家餐厅,前台就是日志门面,后厨就是日志实现。客人来了有的要吃面有的要吃饭,如果没有前台,吃面的要找到煮面的师傅,要吃饭的要找到煮饭的师傅,而如果有前台服务员就不需要上面操作,直接告诉服务员,让他帮你找。回到代码中,有很多厂商提供了日志服务,如果开发者直接调用某个厂商的API,那么当这个厂商出现问题要使用其他厂商的服务,所有的API都要改,需要大调整,代码的耦合度非常高。如果在开发中程序员直接调用SLF4J提供的API,让SLF4J帮你做上面的工作,就能实现解耦合。
日志级别
日志级别从低到高
- trace:微量,少许的意思,级别最低
- debug: 调试时候的关键信息打印
- info: 普通的打印信息(默认日志级别)
- warm: 警告
- error: 错误信息,级别较高的错误日志信息
- fatal: 致命的,程序崩溃
:::success
日志级别设置
:::
日志级别设置需要在配置文件中设置“logging.level"
logging:
level:
root: error #设置根路径的日志级别
com:
example:
demo:
controller: warn #设置controller包的日志级别
@Controller
@ResponseBody //表示返回的是数据而非页面
@RequestMapping("/user")
public class UserController {
//1. 得到日志对象
private static final Logger logger = LoggerFactory.getLogger(UserController.class);//表示该日志来自于哪个类
@RequestMapping("/hi")
public String sayHi() {
//写日志
logger.trace("trace级别");
logger.debug("debug级别");
logger.info("info级别");
logger.warn("warn级别");
logger.error("error级别");
return "hi";
}
}
点击运行后,我们发现控制台空空如也,这是因为我们设置根路径的日志级别为error
发送请求,调用sayHi方法
日志打印如下
打印了warn和error日志,这是因为我们配置了controller包的最小日志级别是warn
:::info
日志级别的作用
:::
- 帮助我们快速筛选重要的日志
- 不同环境实现不同日志级别的设置
日志持久化
咱们上面的日志都是输出在控制台上,但是在生产环境上咱们需要将日志保存下来,以便出现问题之后追溯问题,这就需要持久化。
logging:
file:
path: D:\\javaee_advanced\\Test.2023.5.28
注意:后序的日志是采用续写的方式,而不是覆盖。并且当文件达到10M时会自动给你创建一个新的文件。
logging:
file:
name: springboot.log
如果没有指定路径,只给文件名会默认给你保存到项目中。
更简单的日志输出
在输出日志时,都需要获得日志对象并且每个类都需要添加一遍,非常麻烦。我们可以使用lombok框架的@slf4j注解 简化开发
@Controller
@ResponseBody //表示返回的是数据而非页面
@RequestMapping("/user")
@Slf4j
public class UserController {
//1. 得到日志对象
//private static final Logger logger = LoggerFactory.getLogger(UserController.class);//表示该日志来自于哪个类
@RequestMapping("/hi")
public String sayHi() {
//写日志
log.trace("trace级别");
log.debug("debug级别");
log.info("info级别");
log.warn("warn级别");
log.error("error级别");
return "hi";
}
}
注意:使用Slf4j默认的日志对象是log
lombok原理
我们点开target文件(.class文件)就能发现其中的奥秘
发现@Slf4j注解在.class文件中消失了,多了一个日志对象log.
lombok就是在编译阶段将注解变成代码,简化了开发
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!