前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Common.Logging源码解析一

Common.Logging源码解析一

作者头像
郑小超.
发布于 2018-01-26 07:08:36
发布于 2018-01-26 07:08:36
6550
举报
文章被收录于专栏:GreenLeavesGreenLeaves

Common.Logging是Apache下的一个开源日志接口组件,主要用于切换不同的日志库,因为当前流行的日志库有很多向log4j、log4net(log4j的.net版本)等等,所以为了能灵活的切换不同的日志组件以适应不同的系统(在系统的迭代过程中),所以设计了Common.Logging这个组件,下面废话不多说开始解析这个组件。

1、架构分析

首先大致浏览了下这个组件的架构

Common.Logging.Core

Common.Logging

观察文件类型发现以下两点:

(1)、整个组件采用面向接口编程

(2)、抽象工厂,为了解耦必然会采用工厂,通过工厂返回接口(当然这是次要的原因,主要的还是所有的不同的日志实例是相关或者相互依赖的对象)

(3)、必然有一个Manager作为主接口

(2)、(3)点如果不明白请参考抽象工厂(AbstractFactory)模式-创建型模式

2、(LogManager)主接口分析

所谓主接口,就是客户端通过这个类操作日志实例,所以这个类就肩负了所有的初始化工作,下面开始分析LogManager做了哪些初始化工作,以及大致的顺序是怎么样的?

(1)、初始化配置文件阅读器

通过静态构造函数初始化配置文件阅读器实例,关于为什么要用静态构造函数,主要是为了解决多线程的问题,因为web应用程序是多线程的所以通过静态构造函数能解决多线程的问题,编译器会给它加锁。

DefalutConfigurationReader.cs     --这个类默认采用的是去读Web.config文件的方法来读取日志以及日志接口的配置

当编译器执行ConfigurationManager.GetSection()方法时,会触发ConfigurationSectionHandler类的

这个方法回去读取配置文件从而生成LogSetting实例。

 ok,到这一步,就通过构造函数设置完全局的配置文件阅读器实例,下面通过

就能调用配置文件阅读器实例了,这个实例并不包含配置文件的信息,只是存有如何读取配置文件的方法

(2)、生成日志实例工厂类

通过这个属性来创建日志实例工厂类

(3)、开发接口给外部方法

通过这三个方法就可以通过日志实例工厂类来获取对应的日志实例!

ok,整个(LogManager)主接口分析完毕!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-06-07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Common.Logging源码解析二
Common.Logging源码解析一分析了LogManager主入口的整个逻辑,其中第二步生成日志实例工厂类接口分析的很模糊,本随笔将会详细讲解整个日志实例工厂类接口的生成过程! (1)、关于如何生
郑小超.
2018/01/26
5010
Spring.Net学习系列一
废话不多说,如果在看本文之前,你还不知道spring.net是什么,还不知道什么是控制反转、IOC容器、依赖注入、面向切面编程那么请你先去了解这些概念,再来看本文!本系列的文章将会以先贴代码,然后分析代码的方式讲解Spring.Net的一些简单的应用! 1、IObjectFactory接口 IObjectFactory是初始化、配置及管理对象的实际容器,它是所有容器的父接口.IObjectFactory本质上是一个注册了各种对象及其依赖项的高级工厂。通过IObjectFactory接口,可以读取容器内的对象
郑小超.
2018/01/26
5710
C# 日志管理框架:Common.Logging和log4net
‍common logging是一个通用日志接口框架,log4net是一个强大的具体实现框架. common logging可以把输出连接到其他非log类上, 如EntLib的日志、NLog等‍‍‍‍‍‍‍‍‍‍‍‍‍
用户9127601
2022/01/13
1.8K0
C# 日志管理框架:Common.Logging和log4net
Java日志体系(slf4j)
3 slf4j 3.1 简介 与commons-logging相同,slf4j也是一个通用的日志接口,在程序中与其他日志框架结合使用,并对外提供服务。 Simple Logging Facade fo
贾博岩
2018/05/11
5.2K0
MyBatis源码解析之基础模块—Log
上一章节我们一起学习了DataSource源码逻辑。本次我们学习MyBatis的Log日志处理模块。
todobugs
2020/10/21
1.1K0
MyBatis源码解析之基础模块—Log
通用日志
一、背景 为软件开发提供一个现成的、定义良好的、可扩展的日志设施。所谓"现成的"意思为软件开发可以即刻使用,包括API文档、使用实例和库;"定义良好的"表示项目提供良好的使用接口和具有优秀的内部设计;可扩展的意味用户可以进一步扩展功能。 关心软件日志的主要有三类用户:开发人员、系统管理人员和系统运行单位。三类用户各有各的日志需求: l开发人员在写代码的时候经常要输出程序的内部状态,目的可以是开发时的调试,或运行时的维护。 l系统管理人员需要获取软件的状态数据以便进一步配置系统使其正常和高效运行。 l系统运行
张善友
2018/01/29
9030
通用日志
设计模式的征途—3.工厂方法(Factory Method)模式
上一篇的简单工厂模式虽然简单,但是存在一个很严重的问题:当系统中需要引入新产品时,由于静态工厂方法通过所传入参数的不同来创建不同的产品,这必定要修改工厂类的源代码,将违背开闭原则。如何实现新增新产品而不影响已有代码?工厂方法模式为此应运而生。
Edison Zhou
2018/08/21
5950
设计模式的征途—3.工厂方法(Factory Method)模式
slf4j中的桥接器是如何运作的?
阅读分析slf4j的日志源码,发现其中涵盖了许多知识点和优秀的设计,关键它们都是活生生的实践案例。写成系列文章与大家分享,欢迎持续关注。第4篇。
程序新视界
2020/12/01
1.1K0
漫谈模式之创建型模式小结
时间很快,不知不觉漫谈模式系列已经将设计模式-创建型篇写完。本文主要来简单回顾一下之前写的一些内容。
孟君
2023/03/13
3930
logging总结 - log4j2使用流程[归档存储]
<web-app> 2.5 以前要多个依赖 log4j-web,还需要在web.xml配置listener、filter
wuweixiang
2018/08/14
1.6K0
Java中的日志——Java.util.logging、log4j、commons-logging
Java中给项目程序添加log主要有三种方式,一使用JDK中的java.util.logging包,一种是log4j,一种是commons-logging。其中log4j和commons-logging都是apache软件基金会的开源项目。这三种方式的区别如下: Java.util.logging,JDK标准库中的类,是JDK 1.4 版本之后添加的日志记录的功能包。  log4j,最强大的记录日志的方式。可以通过配置 .properties 或是 .xml 的文件, 配置日志的目的地,格式等等。 comm
Java学习123
2018/05/16
1.2K0
Log4j2源码分析系列:(一)配置加载
在实际开发项目中,日志永远是一个绕不开的话题。本系列文章试图以slf4j和log4j2日志体系为例,从源码角度分析日志工作原理。
xiaoxi666
2019/08/29
3K0
Log4j2源码分析系列:(一)配置加载
Mybatis源码解析(二):全局配置文件的解析
<configuration>标签下的子标签很多,目前咱们配置文件只有<environments>标签和<mappers>标签(映射配置文件-下一章单独来讲)
冬天vs不冷
2025/01/21
830
Mybatis源码解析(二):全局配置文件的解析
spring八股记录
model(模型:service、daomapper);view(视图:jsp);controller(控制:servlet)
用户11204257
2024/12/04
670
【旧】G001Spring学习笔记-Spring框架概述和程序间耦合
Spring是一个开放源代码的设计层面框架,他解决的是业务逻辑层和其他各层的松耦合问题,因此它将面向接口的编程思想贯穿整个系统应用。Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson创建。简单来说,Spring是一个分层的JavaSE/EE full-stack(一站式) 轻量级开源框架。
訾博ZiBo
2025/01/06
500
【旧】G001Spring学习笔记-Spring框架概述和程序间耦合
java日志组件介绍(common-logging,log4j,slf4j,logback )
复制来源:java日志组件介绍(common-logging,log4j,slf4j,logback ) common-logging common-logging是apache提供的一个通用的日志接口。用户可以自由选择第三方的日志组件作为具体实现,像log4j,或者jdk自带的logging, common-logging会通过动态查找的机制,在程序运行时自动找出真正使用的日志库。当然,common-logging内部有一个Simple logger的简单实现,但是功能很弱。所以使用common-logg
Ryan-Miao
2018/03/13
1.4K0
java日志组件介绍(common-logging,log4j,slf4j,logback )
日志框架Log4j的学习小记
Java项目的框架基本就是slf4j,slf4j提供了一套规范,也就是门面,而至于后边是如何实现的只要按照人家定义的接口去做就行了。常见的日志框架又springboot自带的logback,还有异步的日志框架log4j,当然还有一些大佬自己做日志框架的。这里作者大概的看了一下日志框架的代码。稍微讲解一下日志框架是怎么做的。
写一点笔记
2022/08/11
2840
日志框架Log4j的学习小记
从源码分析 SpringBoot 的 LoggingSystem → 它是如何绑定日志组件的
SpringBoot2.7 霸王硬上弓 Logback1.3 → 不甜但解渴 实现了 spring-boot 2.x.x 与 logback 1.3.x 的集成,分两步
青石路
2024/08/23
1540
从源码分析 SpringBoot 的 LoggingSystem → 它是如何绑定日志组件的
《手把手教你》系列基础篇(八十七)-java+ selenium自动化测试-框架设计基础-Log4j 2实现日志输出-上篇(详解教程)
Apache Log4j 是一个非常古老的日志框架,并且是多年来最受欢迎的日志框架。 它引入了现代日志框架仍在使用的基本概念,如分层日志级别和记录器。
北京-宏哥
2022/04/27
3810
《手把手教你》系列基础篇(八十七)-java+ selenium自动化测试-框架设计基础-Log4j 2实现日志输出-上篇(详解教程)
设计模式的征途—2.简单工厂(Simple Factory)模式
  工厂模式是最常用的一种创建型模式,通常所说的工厂模式一般是指工厂方法模式。本篇是是工厂方法模式的“小弟”,我们可以将其理解为工厂方法模式的预备知识,它不属于GoF 23种设计模式,但在软件开发中却也应用地比较频繁。此外,工厂方法模式还有一位“大哥”—抽象工厂模式,会在后面进行介绍。
Edison Zhou
2018/08/20
4590
设计模式的征途—2.简单工厂(Simple Factory)模式
相关推荐
Common.Logging源码解析二
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文