druid是号称目前最好的java数据库连接池,温少写的代码中有很多设计模式的思想,其中最重要的一个就是filter-chain设计模式给druid所带来的可扩展性。对此,我很感兴趣,并希望日后借鉴,所以看了看他的源码,以此记录一下。
druid中设计到filter-chain设计模式的类或接口主要有一下几个Filter、FilterAdapter、FilterChain、FilterChainImpl、FilterEventAdapter、FilterManager 以及举例讲讲两个具体的filter:StatFilter、Slf4jLogFilter
具体职责划分如下:
Filter接口:定义了过滤器需要关注的事件,以及可以处理的事件
FilterChain接口:定义了这个过滤器链可以处理的事件,druid的设计中,这两个接口几乎一样。
FilterChainImpl实现类:主要有两个具体作用,其一,具体处理chain中事件的具体事件;其二,将请求分发给下一个filter‘“处理”,注意,这里的处理,并不是去处理这个事件,而是做一些doBefore,doAfter事件。
FilterEventAdapter类:将我们关注的具体事件,通过适配器的设计模式,分为doBefore,do,doAfter三种事件
StatFilter、Slf4jLogFilter类:实现了doBefore,doAfter,这样的话,配置了这两个filter的类就可以做一些切面的事情了
FilterManager类:工具类,提供了filter的spi方式加载方式,也在于一种解耦,将filter和chain解耦,方便日后扩展。
举例数据库的连接过程
其中filter的接口,每个filter只能临时拥有chain,而每个chain拥有filter:
ConnectionProxy connection_connect(FilterChain chain, Properties info) throws SQLException;
FilterChain接口,druid中,最终执行具体方法的是FilterChainImpl,
ConnectionProxy connection_connect(Properties info) throws SQLException; int getFilterSize();
FilterChainImpl具体如何实现调用和分发请求的呢?请看
public ConnectionProxy connection_connect(Properties info) throws SQLException { if (this.pos < filterSize) { return nextFilter().connection_connect(this, info); } Driver driver = dataSource.getRawDriver(); String url = dataSource.getRawJdbcUrl(); Connection nativeConnection = driver.connect(url, info); return wrap(nativeConnection, info); }
从这里,我们可以看到,其实具体数据库的连接,没必要每个filter都具体去做,为什么呢,因为具体的数据库连接这一步是固定的,写不出花来的,不需要每一个filter去实现,所以,filterChainImpl帮我们做了,这个也是filter-chain和其他的chain不同的地方,它的filter更关注切面的处理。而这里好像也看不出来怎么分发,
请看下面代码:
private Filter nextFilter() { Filter filter = getFilters().get(pos++); return filter; }
其实他就是遍历了list,记住list的偏移量,一个个取出来filter的
ok,到这里我们就可以看看filter具体怎样处理事件的。根据上面说的,每个事件被分成了doBefore,do,doAfter那么这是在哪里被切分的呢?这时候就引出了FilterEventAdapter类了
public ConnectionProxy connection_connect(FilterChain chain, Properties info) throws SQLException { connection_connectBefore(chain, info); ConnectionProxy connection = super.connection_connect(chain, info); connection_connectAfter(connection); return connection; } public void connection_connectBefore(FilterChain chain, Properties info) { } public void connection_connectAfter(ConnectionProxy connection) { }
看见了吧,这里就被分成了三个事件了,所以,我们可以肯定,每个filter都是继承的FilterEventAdapter
public ConnectionProxy connection_connect(FilterChain chain, Properties info) throws SQLException { ConnectionProxy connection = null; { long startNano = System.nanoTime(); long startTime = System.currentTimeMillis(); long nanoSpan; long nowTime = System.currentTimeMillis(); JdbcDataSourceStat dataSourceStat = chain.getDataSource().getDataSourceStat(); dataSourceStat.getConnectionStat().beforeConnect(); try { connection = chain.connection_connect(info); nanoSpan = System.nanoTime() - startNano; } catch (SQLException ex) { dataSourceStat.getConnectionStat().connectError(ex); throw ex; } dataSourceStat.getConnectionStat().afterConnected(nanoSpan); if (connection != null) { JdbcConnectionStat.Entry statEntry = getConnectionInfo(connection); dataSourceStat.getConnections().put(connection.getId(), statEntry); statEntry.setConnectTime(new Date(startTime)); statEntry.setConnectTimespanNano(nanoSpan); statEntry.setEstablishNano(System.nanoTime()); statEntry.setEstablishTime(nowTime); statEntry.setConnectStackTrace(new Exception()); dataSourceStat.getConnectionStat().setActiveCount(dataSourceStat.getConnections().size()); } } return connection; }
从标红代码中可以看到,果然如此,druid的filter-chain就是这样设计的。FilterManager工具类就不用过多介绍了。
oracle interceptor-filter 设计模式
http://www.oracle.com/technetwork/java/interceptingfilter-142169.html
相关推荐
这个"参照阿里druid个人整理druid-spring-boot-starter可运行demo"是基于Spring Boot 2.x版本的,包含了Druid的基本配置和使用。为了构建一个完整的Druid配置,你需要以下几个步骤: 1. **依赖添加**:在`pom.xml`...
赠送jar包:druid-spring-boot-starter-1.2.8.jar; 赠送原API文档:druid-spring-boot-starter-1.2.8-javadoc.jar; 赠送源代码:druid-spring-boot-starter-1.2.8-sources.jar; 赠送Maven依赖信息文件:druid-...
赠送jar包:druid-spring-boot-starter-1.1.9.jar; 赠送原API文档:druid-spring-boot-starter-1.1.9-javadoc.jar; 赠送源代码:druid-spring-boot-starter-1.1.9-sources.jar; 赠送Maven依赖信息文件:druid-...
赠送jar包:druid-spring-boot-starter-1.1.10.jar; 赠送原API文档:druid-spring-boot-starter-1.1.10-javadoc.jar; 赠送源代码:druid-spring-boot-starter-1.1.10-sources.jar; 赠送Maven依赖信息文件:druid-...
druid-spring-boot-starter-1.2.8.jar
赠送jar包:druid-spring-boot-starter-1.1.9.jar; 赠送原API文档:druid-spring-boot-starter-1.1.9-javadoc.jar; 赠送源代码:druid-spring-boot-starter-1.1.9-sources.jar; 赠送Maven依赖信息文件:druid-...
druid-spring-boot-starter-1.1.22.jar
在Druid源码包`apache-druid-0.22.1-src.tar.gz`中,我们可以深入研究其内部实现机制。这个源码包包含了Druid的所有源代码,包括核心组件、扩展模块以及相关的测试用例。通过分析源码,我们可以学习到以下几个关键...
标题所指的知识点为“Druid 源码分析 逐层详解”,意味着我们需要深入分析Druid这一开源数据处理工具的源码,并从不同的层面揭示其内部实现机制。 首先,我们来看Druid的构架设计。Druid采用了分层的架构,每个层次...
druid-spring-boot-starter-1.1.24
`Druid` 是阿里巴巴开源的一款高效、强大的数据库连接池组件,全称为 Dynamic Resoult Set(动态结果集),版本号为 `0.2.19`。作为 Java 开发者,了解并掌握 Druid 数据源对于优化数据库访问性能具有重要意义。 1....
赠送jar包:druid-spring-boot-starter-1.2.8.jar; 赠送原API文档:druid-spring-boot-starter-1.2.8-javadoc.jar; 赠送源代码:druid-spring-boot-starter-1.2.8-sources.jar; 赠送Maven依赖信息文件:druid-...
Druid是阿里巴巴开源的一款高效、强大的数据库连接池组件,它不仅提供了数据库连接池功能,还集成了监控、SQL解析、执行性能统计等多种实用特性,是Java开发中常用的数据库连接池之一。Spring Boot作为微服务开发的...
通过对 `apache-druid-0.21.1-src` 源码的深入研究,我们可以学习到 Druid 如何实现高并发、低延迟的查询,以及如何优化数据摄入和存储。这对于大数据领域的开发者来说,是一份宝贵的参考资料。
赠送jar包:druid-1.2.8.jar; 赠送原API文档:druid-1.2.8-javadoc.jar; 赠送源代码:druid-1.2.8-sources.jar; 赠送Maven依赖信息文件:druid-1.2.8.pom; 包含翻译后的API文档:druid-1.2.8-javadoc-API文档-...
阿里巴巴数据连接池druid,性能远超dpcb和c3p0,资源来自maven仓库
赠送jar包:druid-1.2.8.jar; 赠送原API文档:druid-1.2.8-javadoc.jar; 赠送源代码:druid-1.2.8-sources.jar; 赠送Maven依赖信息文件:druid-1.2.8.pom; 包含翻译后的API文档:druid-1.2.8-javadoc-API文档-...
该项目为基于Java语言的阿里巴巴Druid数据源设计源码,共包含6149个文件,涵盖5027个Java源代码文件、623个SQL文件、173个文本文件、94个数据文件、50个HTML文件、34个属性文件、23个XML文件、11个PNG图像文件、10个...
druid-spring-boot-starter-1.1.10.jar
druid-spring-boot-starter-1.2.8-sources.jar