#最大活動物件數
redis.pool.maxtotal=1000
#最大能夠保持idel狀態的物件數
redis.pool.maxidle=100
#最小能夠保持idel狀態的物件數
redis.pool.minidle=50
#當池內沒有返回物件時,最大等待時間
redis.pool.maxwaitmillis=10000
#當呼叫borrow object方法時,是否進行有效性檢查
redis.pool.testonborrow=true
#當呼叫return object方法時,是否進行有效性檢查
redis.pool.testonreturn=true
#「空閒鏈結」檢測線程,檢測的週期,毫秒數。如果為負值,表示不執行「檢測線程」。預設為-1.
redis.pool.timebetweenevictionrunsmillis=30000
#向呼叫者輸出「鏈結」物件時,是否檢測它的空閒超時;
redis.pool.testwhileidle=true
# 對於「空閒鏈結」檢測線程而言,每次檢測的鏈結資源的個數。預設為3.
redis.pool.numtestsperevictionrun=50
#redis伺服器的ip
redis.ip=******
#redis伺服器的port
redis1.port=6379
詳解:
maxactive:控制乙個pool可分配多少個jedis例項,通過pool.getresource()來獲取;如果賦值為-1,則表示不限制;如果pool已經分配了maxactive個jedis例項,則此時pool的狀態就成exhausted了,在jedispoolconfig
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連線池報錯處理
在使用jedis連線池模式下,比較常見的報錯如下 redis.clients.jedis.exceptions.jedisconnectionexception could not get a resource from the pool 已華為雲的分布式快取服務 redis 為例,首先確認例項是正...
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...