SpringBoot日志:Springboot内部采用的是Commons Logging 进行日志记录,但在底层为Java Util,Loggin,Log4J,Logback等日志框架提供默认配置,虽然有很多可用日志框架,一般使用SpringBoot默认的Logback即可,Logback效率更高,支持SLF4J。
1. 日志依赖:
org.springframework.boot
spring-boot-starter-logging
注:spring-boot-starter中包含了springboot-starter-logging
2. 日志格式:
注:输出如下内容:
时间日期:精确到毫秒,可以用于排序 日志级别:ERROR,WARN,INFO,DEBUG,TRACE;
进程ID: 分割符:采用---来标识日志开始部分;
线程名:方括号括起来; Logger名:通常使用源代码的类名;
日志内容:日志输出的信息
3.日志输出级别:
SpringBoot默认输出的日志级别为:INFO,WARN,ERROR;
日志级别从低到高为:TRACE 如需输出更多日志可以通过以下方式开启: 命令模式配置:Java -jar app.jar -debug=true 这种命令会被SpringBoot解析,优先级最高; 资源文件配置:application.properties 配置debug=true 即可 4.输出级别配置: 所有支持的日志记录系统都可以在spring环境中设置记录级别(application.properties) 格式为:logging.level.* = LEVEL; loggging.level :日志级别控制前缀,*为表名或loggger名; LEVEL 选项:TRACE,DEBUG,INFO,WARN,ERROR,FATAL,OFF; 例子:logging.level.root =DEBUG root日志以DEUBG级别输出; logging.level.com.wuxia=DEBUG com.wuxia包下的所有class以DEBUG级别输出; 5.日志输出位置: 默认情况下,Springboot仅将日志输出到控制台,不会写入到日志文件中去,如果除了控制台输出之外还想写日志文件,则需要在application.proterties设置logging.file或logging.path属性; logging.file :将日志写入到指定的文件中,默认为相对路径,可以设置为绝对路径。 logging.path:将名为spring.log写入到指定的文件夹中 注:如果只配置logging.file,会在项目的当前路径下生成一个xxx.log日志文件 如果只配置logging.path,会在指定文件夹下生成一个日志文件spring.log 二者不能同时用,同时用只logging.file生效; 默认日志文件达到10MB时进行切割,产生新的日志文件:(spring.1.log,spring.2.log); 6.自定义日志配置 日志文件一般在ApplcationContext创建前就初始化了,所以不是必须通过spring的配置文件控制,可以外部添加配置文件控制日志: 根据不同的日志系统,按如下规则建立配置文件名,就可以被加载: Logback:logback-spring.xml,logback-spring.groovy,logback.xml,logback.groovy; Log4j:log4j-spring.properties,log4j-spring.xml,log4j.properties,log4j.xml; 推荐使用带有spring的文件名作为日志文件;一般使用logback-spring.xml 作为配置文件;文件放在resources下; 7.打印日志: 注:每次打印日志都要写private static Logger log=LogManager.getLogger("UserService");很麻烦,可以使用lombok插件; 在类上写上注解@Slf4j: #日志配置
logging.level.root=info
logging.level.org.springframework.web=debug
logging.level.org.mybatis= INFO
logging.level.com.com.fyl.navigation.dao=debug
logging.file.max-size=10MB
logging.file.max-history=10
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
private static Logger logger= LogManager.getLogger("UserService");
@Override
public List
@Service
@Slf4j
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public List