ktv,springBoot日志结构主动装备与原理,河

频道:社会万象 日期: 浏览:139

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

热门
最新
推荐
标签