1. 程式人生 > >Jedis Pool Options (Jedis 2.9.0)

Jedis Pool Options (Jedis 2.9.0)

  • maxActive:控制一個pool可分配多少個jedis例項,通過pool.getResource()來獲取;如果賦值為-1,則表示不限制;如果pool已經分配了maxActive個jedis例項,則此時pool的狀態為exhausted。
  • maxIdle:控制一個pool最多有多少個狀態為idle(空閒)的jedis例項;
  • blockWhenExhausted:表示當pool中的jedis例項都被allocated完時,是否阻塞,否則直接丟擲異常。
  • maxWait:表示當borrow一個jedis例項時,最大的等待時間,如果超過等待時間,則直接丟擲JedisConnectionException;
  • testOnBorrow:在borrow一個jedis例項時,是否提前進行validate操作;如果為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