美文网首页
使用common pool2实现资源的池化

使用common pool2实现资源的池化

作者: luhuancheng | 来源:发表于2018-04-22 21:52 被阅读0次
空间换时间
  • 在大型应用中为了提升效率,通常会把需要创建的对象提前创建出来,这就是所谓的空间换时间手段。比如jdbc的连接池,通常连接数据库等外部中间件时,需要经历对象的创建、TCP连接的建立等一系列动作之后,连接方能使用;
使用common pool2实现资源的池化
  • 需要使用池的配置类GenericObjectPoolConfig来进行池的一些属性配置
  • 实现接口PooledObjectFactory,创建一个作为池管理资源的工厂类
  • 内建的池实现类GenericObjectPool,实例化该类时需要传入PooledObjectFactory的实现类以及池的配置类GenericObjectPoolConfig
实例,实现rabbitmq channel的池化
// 实现接口PooledObjectFactory
package com.luhc.pool;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.ConnectionFactory;
import org.apache.commons.pool2.PooledObject;
import org.apache.commons.pool2.PooledObjectFactory;
import org.apache.commons.pool2.impl.DefaultPooledObject;

/**
 * @author luhuancheng
 * @since 2018/4/22 21:37
 */
public class MyRabbitMQChannelPoolFactory implements PooledObjectFactory<Channel> {

    private ConnectionFactory factory;

    public MyRabbitMQChannelPoolFactory(ConnectionFactory factory) {
        this.factory = factory;
    }

    @Override
    public PooledObject<Channel> makeObject() throws Exception {
        // 池对象创建实例化资源
        return new DefaultPooledObject<>(factory.newConnection().createChannel());
    }

    @Override
    public void destroyObject(PooledObject<Channel> p) throws Exception {
        // 池对象销毁资源
        if (p != null) {
            p.getObject().close();
        }
    }

    @Override
    public boolean validateObject(PooledObject<Channel> p) {
        // 验证资源是否可用
        return p.getObject().isOpen();
    }

    @Override
    public void activateObject(PooledObject<Channel> p) throws Exception {

    }

    @Override
    public void passivateObject(PooledObject<Channel> p) throws Exception {

    }
}

// 自定义池
package com.luhc.pool;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.ConnectionFactory;
import org.apache.commons.pool2.impl.GenericObjectPool;
import org.apache.commons.pool2.impl.GenericObjectPoolConfig;

/**
 * @author luhuancheng
 * @since 2018/4/22 21:41
 */
public class MyRabbitMQChannelPool {

    private GenericObjectPool<Channel> pool;

    public MyRabbitMQChannelPool(ConnectionFactory factory, GenericObjectPoolConfig poolConfig) {
        this.pool = new GenericObjectPool<>(new MyRabbitMQChannelPoolFactory(factory), poolConfig);
    }

    public Channel getChannel() {

        try {
            return pool.borrowObject();
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    public void returnChannel(Channel channel) {
        if (channel != null) {
            pool.returnObject(channel);
        }
    }
}

相关文章

  • 使用common pool2实现资源的池化

    空间换时间 在大型应用中为了提升效率,通常会把需要创建的对象提前创建出来,这就是所谓的空间换时间手段。比如jdbc...

  • apache common pool2简介

    一、摘要 apache common pool2 作为对象池模式的一种实现,通过重用来分摊复杂对象的创建代价。被广...

  • Common-pool2使用

    apache-common-pool2使用步骤 1、定义池保有类,该类实现PoolObject接口; 2、定义Fa...

  • 关于线程池的五种实现方式,七大参数,四种拒绝策略

    1 池化技术之线程池 什么是池化技术?简单来说就是优化资源的使用,我准备好了一些资源,有人要用就到我这里拿,用完了...

  • 关于线程池的五种实现方式,七大参数,四种拒绝策略

    池化技术之线程池 什么是池化技术?简单来说就是优化资源的使用,我准备好了一些资源,有人要用就到我这里拿,用完了就还...

  • 31.内存池、进程池、线程池

    首先介绍一个概念池化技术 。池化技术就是:提前保存大量的资源,以备不时之需以及重复使用。池化技术应用广泛,如内存池...

  • 线程池的原理

    参考 深入Java源码理解线程池原理 线程池是对CPU利用的优化手段 线程池使用池化技术实现,替他的实现还有连接池...

  • 池化技术(JAVA)分析

    简介 池化技术能够减少资源对象的创建次数,提高程序的性能,特别是在高并发下这种提高更加明显。使用池化技术缓存的资源...

  • Java ThreadPoolExecutor详解

    ThreadPoolExecutor是Java语言对于线程池的实现。池化技术是一种复用资源,减少开销的技术。线程是...

  • 深入解析Java ThreadPoolExecutor

    ThreadPoolExecutor是Java语言对于线程池的实现。池化技术是一种复用资源,减少开销的技术。线程是...

网友评论

      本文标题:使用common pool2实现资源的池化

      本文链接:https://www.haomeiwen.com/subject/ckchlftx.html