基本使用:
本篇讲日志的基本使用,通过logback-spring.xml自定义的生产配置见:SpringBoot自定义日志配置详解
- SpringBoot默认配置好了日志,可以直接使用
Logger logger = LoggerFactory.getLogger(getClass());
@Test
public void contextLoads() {
//日志的级别;
//由低到高 trace<debug<info<warn<error
logger.trace("这是trace日志...");
logger.debug("这是debug日志...");
logger.info("这是info日志...");
logger.warn("这是warn日志...");
logger.error("这是error日志...");
}
-
采用注解简化:(免除每个类构造日志对象)
1.引入依赖:
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
2.添加@Slf4j注解:之后就可以直接用log对象打印。(如果报找不到log)需要给IDEA安装lombok插件即可
@Slf4j
@RestController
@RequestMapping("/user")
public class UserController {
@RequestMapping(value = "/signUp", method = RequestMethod.POST)
public Result insertUser(@RequestBody JSONObject obj, HttpSession session) {
log.debug("log info");
}
}
-
日志输出等级控制:
SpringBoot默认配置的日志等级为Info,可以通过在properties文件中配置。
#root默认会对所有输出产生作用 logging: level: root: debug #如果只想对自己的包下或者具体的类设置等级可以详细配置,例如:只对com.zd.iot包起作用 logging: level: com.zd.iot: debug
-
日志输出格式配置:
日志输出格式: %d表示日期时间, %thread表示线程名, %-5level:级别从左显示5个字符宽度 %logger{50} 表示logger名字最长50个字符,否则按照句点分割。 %msg:日志消息, %n是换行符 例如: %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
例如:
# 在控制台输出的日志的格式 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
-
日志输出位置配置:默认是控制台(一般file和path只需要配置一个即可)
# 可以指定完整的路径或相对路径; logging.file=G:/springboot.log # 在当前磁盘的根路径下创建spring文件夹和里面的log文件夹;使用 spring.log 作为默认文件 logging.path=/spring/log
表格对比
logging.file logging.path Example Description (none) (none) 只在控制台输出 指定文件名 (none) my.log 输出日志到my.log文件 (none) 指定目录 /var/log 输出到指定目录的 spring.log 文件中 -
指定自定义配置文件:(目前项目中未使用,等待更新)
给类路径下放上每个日志框架自己的配置文件即可;SpringBoot就不使用他默认配置的了
LoggingSystem Customization Logback logback-spring.xml
,logback-spring.groovy
,logback.xml
orlogback.groovy
Log4j2 log4j2-spring.xml
orlog4j2.xml
更高级用法见:SpringBoot自定义配置日志