Jedis連線池的使用

2021-06-21 03:37:38 字數 2961 閱讀 7826

所需jar:jedis-2.1.0.jar和commons-pool-1.5.4.jar

jedis操作步驟如下:

1->獲取jedis例項需要從jedispool中獲取;

2->用完jedis例項需要返還給jedispool;

3->如果jedis在使用過程中出錯,則也需要還給jedispool;

package com.ljq.utils;

import redis.clients.jedis.jedis;

import redis.clients.jedis.jedispool;

import redis.clients.jedis.jedispoolconfig;

/**

* redis操作介面

* * @author 林計欽

* @version 1.0 2013-6-14 上午08:54:14

*/public class redisapi

return pool;

}/**

* 返還到連線池

* * @param pool

* @param redis

*/public static void returnresource(jedispool pool, jedis redis)

}/**

* 獲取資料

* * @param key

* @return

*/public static string get(string key) catch (exception e) finally

return value;

}}

**說明:

a、獲取jedis例項時,實際上可能有兩類錯誤。

一類是pool.getreource(),得不到可用的jedis例項;

另一類是jedis.set/get時出錯也會丟擲異常;

為了實現區分,所以根據instance是否為null來實現,如果為空就證明instance根本就沒初始化,也就不用return給pool;如果instance不為null,則證明是需要返還給pool的;

b、在instance出錯時,必須呼叫returnbrokenresource返還給pool,否則下次通過getresource得到的instance的緩衝區可能還存在資料,出現問題!

jedispool的配置引數很大程度上依賴於實際應用需求、軟硬體能力。以前沒用過commons-pool,所以這次花了一整天專門看這些引數的含義。。。jedispool的配置引數大部分是由jedispoolconfig的對應項來賦值的。

maxactive:控制乙個pool可分配多少個jedis例項,通過pool.getresource()來獲取;如果賦值為-1,則表示不限制;如果pool已經分配了maxactive個jedis例項,則此時pool的狀態為exhausted。

maxidle:控制乙個pool最多有多少個狀態為idle(空閒)的jedis例項;

whenexhaustedaction:表示當pool中的jedis例項都被allocated完時,pool要採取的操作;預設有三種。

when_exhausted_fail --> 表示無jedis例項時,直接丟擲nosuchelementexception;

when_exhausted_block --> 則表示阻塞住,或者達到maxwait時丟擲jedisconnectionexception;

when_exhausted_grow --> 則表示新建乙個jedis例項,也就說設定的maxactive無用;

maxwait:表示當borrow乙個jedis例項時,最大的等待時間,如果超過等待時間,則直接丟擲jedisconnectionexception;

testonborrow:在borrow乙個jedis例項時,是否提前進行alidate操作;如果為true,則得到的jedis例項均是可用的;

testonreturn:在return給pool時,是否提前進行validate操作;

testwhileidle:如果為true,表示有乙個idle object evitor執行緒對idle object進行掃瞄,如果validate失敗,此object會被從pool中drop掉;這一項只有在timebetweenevictionrunsmillis大於0時才有意義;

timebetweenevictionrunsmillis:表示idle object evitor兩次掃瞄之間要sleep的毫秒數;

numtestsperevictionrun:表示idle object evitor每次掃瞄的最多的物件數;

minevictableidletimemillis:表示乙個物件至少停留在idle狀態的最短時間,然後才能被idle object evitor掃瞄並驅逐;這一項只有在timebetweenevictionrunsmillis大於0時才有意義;

softminevictableidletimemillis:在minevictableidletimemillis基礎上,加入了至少minidle個物件已經在pool裡面了。如果為-1,evicted不會根據idle time驅逐任何物件。如果minevictableidletimemillis>0,則此項設定無意義,且只有在timebetweenevictionrunsmillis大於0時才有意義;

lifo:borrowobject返回物件時,是採用default_lifo(last in first out,即類似cache的最頻繁使用佇列),如果為false,則表示fifo佇列;

其中jedispoolconfig對一些引數的預設設定如下:

testwhileidle=true

minevictableidletimemills=60000

timebetweenevictionrunsmillis=30000

numtestsperevictionrun=-1

Jedis連線池的使用

所需jar jedis 2.1.0.jar和commons pool 1.5.4.jar jedis操作步驟如下 1 獲取jedis例項需要從jedispool中獲取 2 用完jedis例項需要返還給jedispool 3 如果jedis在使用過程中出錯,則也需要還給jedispool 如下 pac...

Jedis連線池的使用

所需jar jedis 2.1.0.jar和commons pool 1.5.4.jar jedis操作步驟如下 1 獲取jedis例項需要從jedispool中獲取 2 用完jedis例項需要返還給jedispool 3 如果jedis在使用過程中出錯,則也需要還給jedispool packag...

Jedis連線池的使用

所需jar jedis 2.1.0.jar和commons pool 1.5.4.jar jedis操作步驟如下 1 獲取jedis例項需要從jedispool中獲取 2 用完jedis例項需要返還給jedispool 3 如果jedis在使用過程中出錯,則也需要還給jedispool 如下 pac...