设为首页 收藏本站
查看: 663|回复: 0

[经验分享] Apache common pool 用法

[复制链接]

尚未签到

发表于 2017-1-1 11:28:39 | 显示全部楼层 |阅读模式
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中获取的实例。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-322413-1-1.html 上篇帖子: Tomcat集群——使用apache负载 下篇帖子: Apache poi 导出excel实例
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表