java资源池的实现
1、资源池
对于共享资源,有⼀个很著名的设计模式:资源池。该模式正是为了解决资源频繁分配、释放所造成的问题的。把该模式应⽤到数据库连接管理领域,就是建⽴⼀个数据库连接池,提供⼀套⾼效的连接分配、使⽤策略,最终⽬标是实现连接的⾼效、安全的复⽤。还有⼀类对象池⼤家可能不太了解,对于nio中有个堆外内存,netty的ByteBuf对象的实现就是⼀个可复⽤的对象池来提⾼性能。连接池⼤家平时听的多,使⽤也多,但是⾃⼰实现应该⽐较少。
1.1 LinkedBlockingQueue应⽤实例
并发库中的BlockingQueue是⼀个⽐较好玩的类,顾名思义,就是阻塞队列。该类主要提供了两个⽅法put()和take(),前者将⼀个对象放到队列中,如果队列已经满了,就等待直到有空闲节点;后者从head取⼀个对象,如果没有对象,就等待直到有可取的对象。
⼀个简单的资源池可以使⽤LinkedBlockingQueue实现,需要的对象如下:
ICommonPool : 定义通⽤池,借出对象和归还对象
PoolFactory :对象⼯⼚,负责创建和销毁对象
PoolConfig : 对象池的配置(最⼤连接数和最⼩连接数)
BaCommonPool :对象池的主要基础实现
1.2 commons-pool2实现资源池
PooledObject(池化对象) PooledObjectFactory(对象⼯⼚) ObjectPool (对象池)
<dependency>
<groupId>s</groupId>
<artifactId>commons-pool2</artifactId>
<version>2.6.2</version>
</dependency>
使⽤
@Autowired
private TestObjectPool testObjectPool;
public void test(){
TestObject testObject =null;
try{
testObject = testObjectPool.borrowObject();
//省略业务代码...
}catch(Exception e){
e.printStackTrace();
}finally{
if(testObject !=null){
//最终归还对象到对象池
}
}
}
注意:使⽤对象要,需要returnObject,为了⽅便管理,可以参考数据库连接池的rvice层的设计,当rvice抛出异常时,捕获异常,释放对象。
参考: