资讯专栏INFORMATION COLUMN

日志框架浅析(一)

fsmStudy / 922人阅读

摘要:简介常用的日志主流框架基本上是基于搭配来实现日志输出依赖包解析我们获取日志实体代码具体获取日志实体源码这里类就必须在中声明并且通过调用获取一个实现了的实例这里获取单例是通过饿汉式依赖实体改成依赖一个接口是否更加优雅然后通过的

SLF4J&&Logback 简介

常用的日志主流框架基本上是基于slf4j搭配logback来实现日志输出
依赖jar包:slf4j-api-x.x.x.jar,logback-classic-x.x.x.jar,logback-core-x.x.x.jar

解析

我们获取日志实体代码:
Logger log = LoggerFactory.getLogger("test");

具体获取日志实体源码:

public static Logger getLogger(String name) {
   ILoggerFactory iLoggerFactory = getILoggerFactory();
   return iLoggerFactory.getLogger(name);
}

public static ILoggerFactory getILoggerFactory() {
    if (INITIALIZATION_STATE == UNINITIALIZED) {
       INITIALIZATION_STATE = ONGOING_INITIALIZATION;
       performInitialization();
    }
    switch (INITIALIZATION_STATE) {
    case SUCCESSFUL_INITIALIZATION:
       return StaticLoggerBinder.getSingleton().getLoggerFactory();
    case NOP_FALLBACK_INITIALIZATION:
       return NOP_FALLBACK_FACTORY;
    case FAILED_INITIALIZATION:
       throw new IllegalStateException(UNSUCCESSFUL_INIT_MSG);
    case ONGOING_INITIALIZATION:
       return TEMP_FACTORY;
    }
    throw new IllegalStateException("Unreachable code");
}

这里类StaticLoggerBinder 就必须在logback-classic-x.x.x.jar中声明,并且通过调用StaticLoggerBinder.getSingleton().getLoggerFactory()获取一个实现了ILoggerFactory的实例
(这里获取单例是通过饿汉式,依赖StaticLoggerBinder实体改成依赖一个接口是否更加优雅,然后通过SPI的方式来获取不同包里面的的不同实现)

    public interface ILoggerFactory {
        public Logger getLogger(String name);
    }

获取一个实现了Logger接口的实例,具体接口的实现是在logback-classic-x.x.x.jar中,结合logback-core-x.x.x.jar包括了所有的日志输出的细节

小结

logback是通过直接实现接口来搭配slf4j使用

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/67006.html

相关文章

  • 日志框架浅析(二)

    摘要:简介依赖包解析并没有实现相应的接口所以加了一层桥接层包里面的内容来实现对的调用里面的代码很简单只有个类关键的两个类是和对应的方法源码实现了的接口调用方法获取实现了的接口并且实际代理了类所以对的所有方法调用最终调用的都是对应的方法小 SLF4J&&Log4j 简介 依赖jar包:slf4j-api-x.x.x.jar,log4j.jar,slf4j-log4j12.jar 解析 log4...

    tuomao 评论0 收藏0
  • python的logging 模块浅析

    摘要:的继承关系使用做日志输出时,首先我们需要一个创建一个对象。再设计多级别的日志系统时,尤其要注意这点。当然,这样做其实是有悖于的本意的。是什么是一个程序内全局唯一的,所有对象的祖先。因此,直接修改是危险的。 0x00 python logging的继承关系 使用python做日志输出时,首先我们需要一个创建一个Logger对象:import logging; logger = log...

    cooxer 评论0 收藏0

发表评论

0条评论

fsmStudy

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<