Jedis客户端testOnBorrow、testOnReturn属性分析
在上一篇博客,将testOnBorrow和testOnReturn两个属性设置为true,用以解决"Could not get a resource from the pool"异常。通过这篇博客,来介绍这两个属性。
一、TestOnBrrow属性
- 属性介绍
当该属性为true时,在调用borrowObject方法返回连接前,会调用validated方法进行校验。若校验失败,连接会从连接池中移除并销毁。同时会尝试重新借一个新的连接对象。
3. 代码侧使用
①. 初始化
在创建JedisPool对象时,构造一个JedisFactory对象,该对象为PooledObjectFactory接口的实现类,后续的检验操作,是通过该接口定义的validateObject方法完成
②.调用
JedisPool.getResource()->pool.borrowObject()->JedisFactory.validateObject(PooledObject)–>ping通,不通销毁
③. 校验逻辑
5. 结论
若testOnBorrow属性设置为true,从连接池中获取对象时,会进行检查,检查不通过,会从连接池中移走并销毁。
检查是通过PooledObjectFactory接口的validateObject方法完成。Jedis客户端,提供JedisFactory对象,用于校验。若ping不通,则校验失败。
JedisFactory对象,是在连接池创建时,构造。
二.TestOnReturn属性
- 属性介绍
通过returnObject方法规则连接到连接池时,会调用validateObject方法,校验当前连接,校验不通过,销毁给连接。
- 代码侧使用
JedisCluster.releaseConnection->connection.close()->Pool.returnResource->Pool.returnObject->JedisFactory.validateObject(PooledObject)
- 结论
①.若testOnReturn属性设置为true,归还连接时,会进行检查,检查不通过,销毁。
②.检查是通过PooledObjectFactory接口的validateObject方法完成。Jedis客户端,提供JedisFactory对象,用于校验。若ping不通,则校验失败。