1、日志结构
小张;开发一个大型体系;
1、System.out.println("");将要害数据打印在控制台;去掉?写在一个文件?
2、结构来记载体系的一些运行时信息;日志结构 ; zhanglogging.jar;
3、巨大上的几个功用?异步形式?自动归档?xxxx? zhanglogging-good.jar?
4、将曾经结构卸下来冶?换上新的结构,从头修正之前相关的API;zhanglogging-prefktv,springBoot日志结构自动配备与原理,河ect.jar;
5、JDBC---数据库驱动;
写了一个一致的接口层;日志门面(日志的一个笼统层);logging-abstract.jar;
给项目中导入详细的日志完成就行了;咱们之前的日志结构都是完成的笼统层;
市面上的日志结构;
JUL、JCL、Jboss-logging、logback、log4j、log4j2、slf4j....
日志门面 (日志的笼统层)日志完成JCL(Jakarta Commons Logging) SLF4j(Simple Logging Facade for Java) jboss-loggingLog4j JUL(java.util.logging) Log4j2 Logback
左面选一个门面(笼统层)、右边来选一个完成;
日志门面: SLF4J;
日志完成:Logback;
SpringBoot:底层是Spring结构,Spring邱宏涛结构默许是用JCL;‘
==SpringBoot选用 SLF4j和logback;==
2、SLF4j运用
1、如安在体系中运用SLF4j https://www.slf4j.org
今后开发的时分,日志记载办法的调用,不该该来直接调用日志的完成类,而是调用日志笼统层里边的办法;
给体系里边导入slf4j的jar和 logback的完成jar
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class HelloWorld {
public static void main(String[] args) {
Logger logger = LoggerFactory.getLogger(HelloWorld.class沐);
logger.info("Hello Wor酷7k7eld");
}
}
图示;
每一个日志的完成结构都有自己的配备文件。使ktv,springBoot日志结构自动配备与原理,河用slf4j今后, 配备文件仍是做成日志完成框wrsndm架自己自身的配备文件;
2、遗留问题
a(slf4罗萍简历j+logback): Spring(commons-logging)、Hibernate(jboss-logging)、MyBatis、xxxx
一致日志记载,即使是其他结构和我一同一致运用slf4j进行输出?
怎么让体系中一切的日志都一致到slf4j;
==1、将体系中其他日志结构先扫除出去;==
==2、用中心包来替换原有的日志结构;==
==3、咱们导入slf4j其他的完成==
3、SpringBoot日志联系
org.springframework.booktv,springBoot日志结构自动配备与原理,河t
spring-boot-starter
SpringBoot运用它来做日志功用;
org.springframework.boot
spring-boot-starter-logging
底层依靠联系
总结:
1)、SpringBoot底层也是运用slf4j+logback的方法进行日志记载
2)、SpringBoot也把其他的日志都替换成了slf4j;
3)、中心替换包?
@Su生命线ppressWarnings("rawtypes")
public abstract class LogFactory {
static String UNSUPPORTED_OPERATION_IN_JCL_OVER_SLF4J = "http://www.slf4j.org/codes.html#unsupported_operation_in_jcl_over_slf4j";
static LogFactory logFactory = new SLF4JLogFactory();
4)、假如咱们要引进其他结构?必定要把这个结构的默许日志依靠移除去?
Spring结构用的是commons-logging;
or小手拍拍儿歌视频g.springframework
spring-core
commons-logging
commons-logging
==SpringBootktv,springBoot日志结构自动配备与原理,河能自动适配一切的日志,并且底层运用slf4j+logback的方法记载日志,引进其他结构的时分,只需要把这个结构依靠的日志结构扫除去即可;==
4、日志运用;
1、默许配备
SpringBoot默许帮咱们配备好了日志;
//记载器
Logger logger = LoggerFactory.getLogger(getClass());
@Test
pub口袋妖怪乌黑的魅影攻略lic void contextLoads() {
//System.out.println();
//日志的等级;
//由低到高 trace
//能够调整输出的日志等级;日志就只会在这个等级以今后的高等级收效
logger.trace("这是trace日志...");
logger.debug("这是debug日志...");
//SpringBoot默许给咱们运用的是info级其他,没有指定级其他就用SpringBoot默许规则的等级;root等级
logger.info("这是info日志...");
logger.warn("这是warn日志...");
logger.error("这是error日志...");
}
日志输出格局:
%d表明日期时刻,
%thread表明线程名,
%-5level:等级从左显现5个字符宽度
%logger{50} 表明logger姓名最长50个字符,不然依照句点切割。
%msg:日志音讯,
%n是换行符
-->
%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %lo晨gger{50} - %msg%n
SpringBoot修正日志的默许配备
logging.level.com.atguigu=trace
#logging.path=
# 不指定途径在当时项目下生成springboot.log日志
# 能够指定完好的途径;
#logging.file=G:/springboot.log
# 在当时磁盘ktv,springBoot日志结构自动配备与原理,河的根途径下创立spring文件夹和里边的log文件夹;运用 spring.log 作为默许文件
logging.path=/spring/log
#人类 在控制台输出的日志的格局
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
2、指定配备
给类途径下放上每个日志结构自己的配备文件即可;SpringBoot就不运用他默许配备的了
logback.xml:直接就被日志结构识别了;
logback-spring.柠檬的成效xml:日志结构就不直接加载日志的配备项,由SpringBo1986年属什么属相ot解析日志配备,能够运用SpringBoot的高档Prof方脸合适什么发型ile功用
能够指ktv,springBoot日志结构自动配备与原理,河定某段配备只在某个环境下收效
如:
%d{yyyy-MM-dd HH:mm:ss.SSS} ----> [%thread] ---> %-5level %logger{50} - %msg%n
%d{yyyy-MM-dd HH:m宠文肉多m:ss.SSS} ==== [%thrktv,springBoot日志结构自动配备与原理,河ead] ==== %-5level %logger{50} - %msg%n
假如运用logback.xml作为日志配备文件,还要运用profile功用,会有以下过错
no applicable action for [s机场pringProfile]
5、切换日志结构
能够依照slf4j的日志适配图,进行相关的切换;
slf4j+log4j的方法;
org.springframework.boot
spring-boot-starter-web
logback-classic
ch.qos.logback
log4j-over-slf4j
org.slf4j
org.slf4j
slf4j-log4j12
切换为log4j2
申org.springframework.boot
spring-boot-sta嘴唇发紫是什么原因rter-web
spring-boot-starter-logging
org.springframework.boot
org.二元母猪springframework.boot
spring-boot-starter-log4j2