一、java日志输出演进
(0)控制台输出
System.out.println()
(1)java标准库内置日志包:java.util.logging
Logger logger = Logger.getGlobal();
logger.info("...");
局限性:Logging系统在JVM启动时读取配置文件并完成初始化,一旦开始运行main()方法,就无法修改配置;配置不太方便,需要在JVM启动时传递参数:
-Djava.util.logging.config.file=<config-file-name>
(2)第三方日志库(属于Apache):Commons Logging
特色:可以挂接不同的日志系统,并通过配置文件指定挂接的日志系统。默认情况下,Commons Loggin自动搜索并使用Log4j(Log4j是另一个流行的日志系统),如果没有找到Log4j,再使用JDK Logging。
使用Commons Logging只需要和两个类打交道,并且只有两步:第一步,通过LogFactory获取Log类的实例; 第二步,使用Log实例的方法打日志。
Log log = LogFactory.getLog(X.class);
log.info("...");
Commons Logging是使用最广泛的日志模块;Commons Logging的API非常简单;Commons Logging可以自动检测并使用其他日志模块。
(3)Log4j:一个组件化设计的日志系统
架构:
当我们使用Log4j输出一条日志时,Log4j自动通过不同的Appender把同一条日志输出到不同的目的地。例如:
- console:输出到屏幕;
- file:输出到文件;
- socket:通过网络输出到远程计算机;
- jdbc:输出到数据库
在输出日志的过程中,通过Filter来过滤哪些log需要被输出,哪些log不需要被输出。例如,仅输出ERROR级别的日志。
最后,通过Layout(encoder)来格式化日志信息,例如,自动添加日期、时间、方法名称等信息。
上述结构虽然复杂,但我们在实际使用的时候,并不需要关心Log4j的API,而是通过配置文件(例:log4j2.xml)来配置它。
(4)使用SLF4J和Logback
SLF4J类似于Commons Logging,也是一个日志接口,而Logback类似于Log4j,是一个日志的实现。
为什么有了Commons Logging和Log4j,又会蹦出来SLF4J和Logback?这是因为Java有着非常悠久的开源历史,不但OpenJDK本身是开源的,而且我们用到的第三方库,几乎全部都是开源的。开源生态丰富的一个特定就是,同一个功能,可以找到若干种互相竞争的开源库。因为对Commons Logging的接口不满意,有人就搞了SLF4J。因为对Log4j的性能不满意,有人就搞了Logback。
我们先来看看SLF4J对Commons Logging的接口有何改进。在Commons Logging中,我们要打印日志,有时候得这么写:
int score = 99;
p.setScore(score);
log.info("Set score " + score + " for Person " + p.getName() + " ok.");
拼字符串是一个非常麻烦的事情,所以SLF4J的日志接口改进成这样了:
int score = 99;
p.setScore(score);
logger.info("Set score {} for Person {} ok.", score, p.getName());
我们靠猜也能猜出来,SLF4J的日志接口传入的是一个带占位符的字符串,用后面的变量自动替换占位符,所以看起来更加自然。
如何使用SLF4J?它的接口实际上和Commons Logging几乎一模一样:
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
class Main {
final Logger logger = LoggerFactory.getLogger(getClass());
}
配置文件:logback.xml
参考链接:https://www.liaoxuefeng.com/wiki/1252599548343744/1264739155914176
二、logback.xml标签
标签列表详情:https://my.oschina.net/u/928852/blog/1841371,https://blog.csdn.net/jdx888/article/details/79308713
PATTERN 标签详解:https://www.cnblogs.com/jasenin/p/12692690.html
配置写入不同文件:https://my.oschina.net/u/1000241/blog/1785167