Apache Common-pool2对象池浅析

        Apache Common-pool2包提供了一个通用的对象池技术的实现。能够很方便的基于它来实现本身的对象池,好比DBCP和Jedis他们的内部对象池的实现就是依赖于Common-pool2。
        对象的建立和销毁在必定程度上会消耗系统的资源,虽然jvm的性能在近几年已经获得了很大的提升,对于多数对象来讲,没有必要利用对象池技术来进行对象的建立和管理。可是对于有些对象来讲,其建立的代价仍是比较昂贵的,好比线程、tcp链接、数据库链接等对象,所以对象池技术仍是有其存在的意义。数据库

1.Apache Common-pool2的实现apache

common-pool2包括三个包:swift

    org.apache.commons.pool2:包含了对象池的接口。框架

    org.apache.commons.pool2.impl:包含了对象池的具体实现。jvm

    org.apache.commons.pool2.proxy:包含了对象池的代理。tcp

commons-pool2主要有三大部分构成:ObjectPool,PooledObjectFactory,PooledObject。性能

ObjectPool:咱们直接操做的对象池,主要包括对象的存取和状态的管理,具体对象的建立由PooledObjectFactory来实现。.net

PooledObjectFactory:管理具体对象的状态,好比建立,初始化,验证对象状态和销毁对象。线程

PooledObject:是对须要放入池中的对象的一个包装类,给对象添加了一些额外的信息,如状态信息,建立时间,激活时间,关闭时间等。这些添加的信息方便pool来管理和实现一些特定的操做。代理

他们这三者就构成了一个object pool的基本框架。他们的关系能够用以下的一个图来描述:

简单来讲,就是由PooledObjectFactory建立对象,而后由PooledObject包装一下,放入ObjectPool.

 

 

引用:

apache commons pool2的总体结构分析

Apache Common-pool2对象池分析和应用

Apache common-pool,common-dbcp源码解读与对象池原理剖析

相关文章
相关标签/搜索