`

Apache common pool 用法

阅读更多

Apache Common Pool的使用

http://commons.apache.org/pool/examples.html

<!--[if !supportEmptyParas]--> <!--[endif]-->

Apache CommonPool包括很多已经实现的Pool,常用的Pool有GenericObjectPool,GenericKeyedObjectPool。本文主要讲述如何使用以上两种Pool,其它的用法相似。使用Common Pool需求到Apache网站下载commons-pool.jarcommons-collections.jar两个包。

一.GenericObjectPool

       GenericObjectPool类在rg.apache.commons.pool.impl包中,构造函数如下:

public GenericObjectPool(org.apache.commons.pool.PoolableObjectFactory ,
                        int ,byte ,long , boolean ,boolean )
        由构造函数的定义可以看出,要想使用GenericObjectPool,必须要实现PoolableObjectFactory接口。然后,利用GenericObjectPool的方法获得Pool中的实例。    
<!--[if !supportEmptyParas]--> <!--[endif]-->
<!--[if !supportLists]-->
 
1.           实现PoolableObjectFactory接口

实现PoolableObjectFactory接口,需实现以下方法。其中makeObject在创建实例时调用,通过自定义代码生成并返回需求的实例,activateObject方法在从Pool中拿出一个实例的同时调用,passivateObject方法在实例返还给Pool时调用。

public class MyPoolableObjectFactory implements PoolableObjectFactory {
    //创建对象实例。同时可以分配这个对象适用的资源。
public Object makeObject() throws Exception {
         Connection con = getConnection();
     renturn con;
}
// 销毁对象,实际上提供了释放对象占用资源的接口。
public void destroyObject(Object obj) throws Exception {
     System.out.println("destory Object");
}
//查询对象有效性,这个方法一般在 activateObject 方法执行后调用
public boolean validateObject(Object obj) {
     return true;
}
// 激活一个对象。
public void activateObject(Object obj) throws Exception {
    System.out.println("active object");
}
//挂起一个对象
public void passivateObject(Object obj) throws Exception {
     System.out.println("return object");
}
}
<!--[if !supportEmptyParas]--> <!--[endif]-->
<!--[if !supportLists]-->
 
2.    使用GenericObjectPool

实现PoolableObjectFactory接口后,可以直接使用GenericObjectPool构造函数获得其实例,代码如下:

org.apache.commons.pool.PoolableObjectFactory    factory = new MyPoolableObjectFactory();

GenericObjectPool   pool= new GenericObjectPool(factory, 100,GenericObjectPool.WHEN_EXHAUSTED_BLOCK, 100, true, true);

其中,第一个100为最大激活数,第二个为最大等待数。

<!--[if !supportEmptyParas]--> <!--[endif]-->

2.1.GenericObjectPool参数设置

       GenericObjectPool有几个重要的参数:最大激活数(maxActive),最大等待数(maxWait),最大空闲数(maxIdle),最大空闲时间(maxIdleTime)等。

A). 最大激活数-在Pool中注册,并且正在使用的实例数。调用pool.setMaxActive()方法设置。

B). 最大等待数-在Pool中注册,等待获取实例的申请数。调用pool.setMaxWait()方法设置。

C). 最大空闲数-在Pool中注册,并且正处于空闲状态的实例数。调用pool.setMaxIdle()方法设置

D). 最大空闲时间-在Pool中,实例空闲的最长时间。调用pool.setMinEvictableIdleTimeMillis(maxIdleTime)及pool. setTimeBetweenEvictionRunsMillis(maxIdleTime)方法共同设置。

<!--[if !supportEmptyParas]--> <!--[endif]-->

2.2.Pool中实例的操作

       Pool中实例的操作,主要包括实例的获取及实例的返还。使用完实例之后,需及时返还,否则实例还是处理激活状态,不能为被后面的申请重复利用。

A).实例的获取使用pool.borrowObject()方法

B).实例返还使用pool.returnObject(con)方法,其中con为pool中获取的实例。

<!--[if !supportEmptyParas]--> <!--[endif]-->

二.GenericKeyedObjectPool

       GenericKeyedObjectPool类在rg.apache.commons.pool.impl包中,构造函数如下:

public GenericObjectPool(org.apache.commons.pool.KeyedPoolableObjectFactory ,
                        int ,byte ,long , boolean ,boolean )
        由构造函数的定义可以看出,要想使用GenericKeyedObjectPool,必须要实现KeyedPoolableObjectFactory接口。然后,利用GenericKeyedObjectPool的方法获得Pool中的实例。    
<!--[if !supportEmptyParas]--> <!--[endif]-->
<!--[if !supportLists]-->
 
1.实现KeyedPoolableObjectFactory接口

实现KeyedPoolableObjectFactory接口,需实现以下方法。其中makeObject在创建实例时调用,通过自定义代码生成并返回需求的实例,注意要以一个形参为key创建;activateObject方法在从Pool中拿出一个实例的同时调用,passivateObject方法在实例返还给Pool时调用。要实现的方法比PoolableObjectFactory要实现的方法都多了一个参数key。

public class MyKeyedPoolableObjectFactory implements KeyedPoolableObjectFactory {
    //创建对象实例。同时可以分配这个对象适用的资源。
public Object makeObject(Object key) throws Exception {
         Connection con = getConnection(key);
     renturn con;
}
// 销毁对象,实际上提供了释放对象占用资源的接口。
public void destroyObject(Object key, Object obj) throws Exception {
     System.out.println("destory Object");
}
//查询对象有效性,这个方法一般在 activateObject 方法执行后调用
public boolean validateObject(Object key, Object obj) {
     return true;
}
// 激活一个对象。
public void activateObject(Object key, Object obj) throws Exception {
    System.out.println("active object");
}
//挂起一个对象
public void passivateObject(Object key, Object obj) throws Exception {
     System.out.println("return object");
}
}
<!--[if !supportEmptyParas]--> <!--[endif]-->
<!--[if !supportLists]-->
 
 
2.使用GenericKeyedObjectPool

实现KeyedPoolableObjectFactory接口后,可以直接使用GenericKeyedObjectPool构造函数获得其实例,代码如下:

org.apache.commons.pool.KeyedPoolableObjectFactory factory = new MyKeyedPoolableObjectFactory();

GenericKeyedObjectPool pool= new GenericKeyedObjectPool(factory, 100,GenericObjectPool.WHEN_EXHAUSTED_BLOCK, 100, true, true);

其中,第一个100为最大激活数,第二个为最大等待数。

<!--[if !supportEmptyParas]--> <!--[endif]-->

2.1.GenericKeyedObjectPool参数设置

       GenericKeyedObjectPool参数设置与GenericObjectPool类似。

<!--[if !supportEmptyParas]--> <!--[endif]-->

2.2.Pool中实例的操作

       Pool中实例的操作,主要包括实例的获取及实例的返还。使用完实例之后,需及时返还,否则实例还是处理激活状态,不能为被后面的申请重复利用。带key的Pool的操作方法,也相应的都加了参数key。

A).实例的获取使用pool.borrowObject(Object key)方法

B).实例返还使用pool.returnObject(Object key,Object con)方法,其中con为pool中获取的实例。

分享到:
评论

相关推荐

    Apache common pool2 对象池

    在实际项目中,Apache Commons Pool2 常与其他框架结合使用,如 Apache HttpClient 中的连接池管理,或者在数据库连接池如 HikariCP、C3P0 中也借鉴了对象池的思想。 总的来说,Apache Commons Pool2 是一个强大且...

    CommonPool2Demo

    这个示例代码通常会展示如何创建一个基于Apache Commons Pool2的对象池,以及如何进行对象的获取、使用和返回。以下是一般的步骤: 1. **创建PooledObjectFactory**: 首先,你需要定义一个工厂类,实现...

    commons-pool2-2.5.0-API文档-中英对照版.zip

    使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。 双语对照,边学技术、边学英语。

    redis3.2+jedis2.8.jar+common-pool2.jar+common-pool2-source.rar

    Common-Pool2.jar是Apache Commons Pool库的第二个主要版本,这是一个对象池设计模式的实现,用于提高对象的重用性,减少创建和销毁对象的开销。在Jedis中,它被用于管理Redis连接,通过复用已建立的连接,避免频繁...

    commons-pool2-2.0-API文档-中文版.zip

    赠送jar包:commons-pool2-2.0.jar;...使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。

    Jedis-Common-Pool

    标题中的“Jedis-Common-Pool”指的是Jedis,一个流行的Java客户端库,用于与Redis内存数据存储系统交互,以及Apache Commons Pool 2,这是一个对象池实现,Jedis使用它来管理Redis连接的生命周期,提高性能和资源...

    commons-pool1.5.2 jar包+源码

    **使用方法** 1. 创建`PooledObjectFactory`: 实现这个接口,定义如何创建、验证和销毁对象。 2. 创建`GenericObjectPool`实例: 使用`PooledObjectFactory`实例和`PoolConfig`来初始化池。 3. 获取对象: 调用`...

    apache common系列包的作用以及帮助文档

    `Apache common包的作用.docx` 文件很可能包含了对上述各个组件的详细介绍和使用案例。而 `API.rar` 文件则可能是Apache Commons 的API文档,解压后可以查看详细的类和方法说明,这对于理解和使用Apache Commons ...

    jedis2.9-common-pool

    《Jedis 2.9与Common Pool:Redis客户端与连接池详解》 Redis,作为一款高性能的Key-Value存储系统,被广泛应用于缓存、消息队列等多种场景。在Java开发中,Jedis是一个非常流行的Redis客户端库,而Jedis 2.9版本则...

    Socket-Apache-Commons-Pool2

    套接字-Apache-公共-Pool2 这是一个有关如何使用套接字服务器和客户端的演示。 套接字客户端使用Apache公共pool2来管理套接字。 因此,我们可以在多线程的情况下使用共享套接字。 我使用bernardvai的示例创建了套接...

    common poo. jar包

    "Common Pool"是一个在Java开发中广泛使用的池化库,主要功能是提供对象池化的服务。这个"common poo. jar包"(可能是由于输入错误,正确的名称应该是"common-pool.jar")包含了Apache Commons Pool库的实现,版本为...

    Apache Commons

    Apache Commons 是一个由Apache软件基金会维护的开源项目,它提供了大量的Java类库,这些类库旨在解决常见的...通过使用Apache Commons,开发者可以节省大量编写常见功能的时间,将精力集中在更具挑战性的业务逻辑上。

    apache-commons源码及jar文件

    Apache Commons是一个非常有用的工具包,解决各种实际的通用问题。(附件中提供了该工具包的jar包,及源文件以供研究) BeanUtils Commons-BeanUtils 提供对 Java 反射和自省API的包装 Betwixt Betwixt提供将 ...

    redis-2.1.0 和commons-pool-1.5.6 Java测试redis values 类型

    1. **Jedis连接**: 首先需要在项目中引入Jedis的依赖,配置Redis服务器的IP地址、端口号、密码(如果有的话)等信息,创建Jedis实例,或者使用Apache Commons Pool创建JedisPool。 2. **基本操作**: Redis支持多种...

    jedis+commons-pool2的jar包.rar

    总结起来,Jedis和Apache Commons Pool2的结合使用,为Java开发者提供了一种高效、可靠的Redis连接管理方式,使得在高并发环境中与Redis的交互变得更加便捷和稳定。在实际项目中,确保正确配置和使用这两个库,对于...

    commons-pool-1.5.5-src 源码

    1. **Pool接口和实现**:在`org.apache.commons.pool`包下,定义了基本的`Pool`接口,包括`borrowObject()`, `returnObject()`, `invalidateObject()`等方法,这些都是对象池的基本操作。同时,`...

    apache ftpserver使用讲解

    启动Apache FTP Server的方法因操作系统而异: - **Linux**: ```bash cd %FTP_HOME% bin/ftpd.sh res/conf/ftpd-full.xml ``` - **Windows**: ```bash cd %FTP_HOME% bin/ftpd.bat res/conf/ftpd-full.xml ...

    Apache Commons组件简介.ppt

    12. **Pool**:Apache Commons Pool 提供了一般对象池的实现,对象池可以用于高效地管理资源,减少对象的创建和销毁开销。 通过使用Apache Commons中的这些组件,开发者可以轻松地集成和利用经过验证和优化的代码,...

    java 开发common-*.jar包集合下载

    10. **commons-pool.jar**:Apache Commons Pool库,是一个通用的对象池服务,提供了对象池化机制,可以用于内存管理、数据库连接池等场景,提高系统性能和资源利用率。 这些库都是Java开发中的常用组件,它们在...

    apache jndi 组件

    总结来说,配置Apache JNDI涉及到了JNDI接口的使用,以及相关的支持库,如Apache Commons Collections、DBCP和Pool,它们共同确保了在Java应用程序中高效、稳定地管理和访问命名和目录服务。此外,Tomcat-JNI则为...

Global site tag (gtag.js) - Google Analytics