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.jar和commons-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 Commons Pool2 常与其他框架结合使用,如 Apache HttpClient 中的连接池管理,或者在数据库连接池如 HikariCP、C3P0 中也借鉴了对象池的思想。 总的来说,Apache Commons Pool2 是一个强大且...
这个示例代码通常会展示如何创建一个基于Apache Commons Pool2的对象池,以及如何进行对象的获取、使用和返回。以下是一般的步骤: 1. **创建PooledObjectFactory**: 首先,你需要定义一个工厂类,实现...
使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。 双语对照,边学技术、边学英语。
Common-Pool2.jar是Apache Commons Pool库的第二个主要版本,这是一个对象池设计模式的实现,用于提高对象的重用性,减少创建和销毁对象的开销。在Jedis中,它被用于管理Redis连接,通过复用已建立的连接,避免频繁...
赠送jar包:commons-pool2-2.0.jar;...使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明精准翻译,请放心使用。
标题中的“Jedis-Common-Pool”指的是Jedis,一个流行的Java客户端库,用于与Redis内存数据存储系统交互,以及Apache Commons Pool 2,这是一个对象池实现,Jedis使用它来管理Redis连接的生命周期,提高性能和资源...
**使用方法** 1. 创建`PooledObjectFactory`: 实现这个接口,定义如何创建、验证和销毁对象。 2. 创建`GenericObjectPool`实例: 使用`PooledObjectFactory`实例和`PoolConfig`来初始化池。 3. 获取对象: 调用`...
`Apache common包的作用.docx` 文件很可能包含了对上述各个组件的详细介绍和使用案例。而 `API.rar` 文件则可能是Apache Commons 的API文档,解压后可以查看详细的类和方法说明,这对于理解和使用Apache Commons ...
《Jedis 2.9与Common Pool:Redis客户端与连接池详解》 Redis,作为一款高性能的Key-Value存储系统,被广泛应用于缓存、消息队列等多种场景。在Java开发中,Jedis是一个非常流行的Redis客户端库,而Jedis 2.9版本则...
套接字-Apache-公共-Pool2 这是一个有关如何使用套接字服务器和客户端的演示。 套接字客户端使用Apache公共pool2来管理套接字。 因此,我们可以在多线程的情况下使用共享套接字。 我使用bernardvai的示例创建了套接...
"Common Pool"是一个在Java开发中广泛使用的池化库,主要功能是提供对象池化的服务。这个"common poo. jar包"(可能是由于输入错误,正确的名称应该是"common-pool.jar")包含了Apache Commons Pool库的实现,版本为...
Apache Commons 是一个由Apache软件基金会维护的开源项目,它提供了大量的Java类库,这些类库旨在解决常见的...通过使用Apache Commons,开发者可以节省大量编写常见功能的时间,将精力集中在更具挑战性的业务逻辑上。
Apache Commons是一个非常有用的工具包,解决各种实际的通用问题。(附件中提供了该工具包的jar包,及源文件以供研究) BeanUtils Commons-BeanUtils 提供对 Java 反射和自省API的包装 Betwixt Betwixt提供将 ...
1. **Jedis连接**: 首先需要在项目中引入Jedis的依赖,配置Redis服务器的IP地址、端口号、密码(如果有的话)等信息,创建Jedis实例,或者使用Apache Commons Pool创建JedisPool。 2. **基本操作**: Redis支持多种...
总结起来,Jedis和Apache Commons Pool2的结合使用,为Java开发者提供了一种高效、可靠的Redis连接管理方式,使得在高并发环境中与Redis的交互变得更加便捷和稳定。在实际项目中,确保正确配置和使用这两个库,对于...
1. **Pool接口和实现**:在`org.apache.commons.pool`包下,定义了基本的`Pool`接口,包括`borrowObject()`, `returnObject()`, `invalidateObject()`等方法,这些都是对象池的基本操作。同时,`...
启动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 ...
12. **Pool**:Apache Commons Pool 提供了一般对象池的实现,对象池可以用于高效地管理资源,减少对象的创建和销毁开销。 通过使用Apache Commons中的这些组件,开发者可以轻松地集成和利用经过验证和优化的代码,...
10. **commons-pool.jar**:Apache Commons Pool库,是一个通用的对象池服务,提供了对象池化机制,可以用于内存管理、数据库连接池等场景,提高系统性能和资源利用率。 这些库都是Java开发中的常用组件,它们在...
总结来说,配置Apache JNDI涉及到了JNDI接口的使用,以及相关的支持库,如Apache Commons Collections、DBCP和Pool,它们共同确保了在Java应用程序中高效、稳定地管理和访问命名和目录服务。此外,Tomcat-JNI则为...