Jedis客户端testOnBorrow、testOnReturn属性分析

Jedis客户端testOnBorrow、testOnReturn属性分析

在上一篇博客,将testOnBorrow和testOnReturn两个属性设置为true,用以解决"Could not get a resource from the pool"异常。通过这篇博客,来介绍这两个属性。
一、TestOnBrrow属性

  1. 属性介绍

当该属性为true时,在调用borrowObject方法返回连接前,会调用validated方法进行校验。若校验失败,连接会从连接池中移除并销毁。同时会尝试重新借一个新的连接对象。

Jedis客户端testOnBorrow、testOnReturn属性分析_第1张图片
3. 代码侧使用
①. 初始化
在这里插入图片描述
在这里插入图片描述
Jedis客户端testOnBorrow、testOnReturn属性分析_第2张图片
Jedis客户端testOnBorrow、testOnReturn属性分析_第3张图片

在创建JedisPool对象时,构造一个JedisFactory对象,该对象为PooledObjectFactory接口的实现类,后续的检验操作,是通过该接口定义的validateObject方法完成

②.调用

JedisPool.getResource()->pool.borrowObject()->JedisFactory.validateObject(PooledObject)–>ping通,不通销毁

③. 校验逻辑
Jedis客户端testOnBorrow、testOnReturn属性分析_第4张图片
5. 结论

若testOnBorrow属性设置为true,从连接池中获取对象时,会进行检查,检查不通过,会从连接池中移走并销毁。
检查是通过PooledObjectFactory接口的validateObject方法完成。Jedis客户端,提供JedisFactory对象,用于校验。若ping不通,则校验失败。
JedisFactory对象,是在连接池创建时,构造。

二.TestOnReturn属性

  1. 属性介绍
    Jedis客户端testOnBorrow、testOnReturn属性分析_第5张图片

通过returnObject方法规则连接到连接池时,会调用validateObject方法,校验当前连接,校验不通过,销毁给连接。

  1. 代码侧使用

JedisCluster.releaseConnection->connection.close()->Pool.returnResource->Pool.returnObject->JedisFactory.validateObject(PooledObject)

  1. 结论

①.若testOnReturn属性设置为true,归还连接时,会进行检查,检查不通过,销毁。
②.检查是通过PooledObjectFactory接口的validateObject方法完成。Jedis客户端,提供JedisFactory对象,用于校验。若ping不通,则校验失败。

你可能感兴趣的:(异常信息,java,redis)