redis之如何配置jedisPool引數

2021-09-02 20:46:55 字數 4137 閱讀 8802

jedispool的配置引數很大程度上依賴於實際應用需求、軟硬體能力,jedispool的配置引數大部分是由jedispoolconfig的對應項來賦值的。

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

jedispoolconfig config = new jedispoolconfig();

//連線耗盡時是否阻塞, false報異常,ture阻塞直到超時, 預設true

config.setblockwhenexhausted(true);

//設定的逐出策略類名, 預設defaultevictionpolicy(當連線超過最大空閒時間,或連線數超過最大空閒連線數)

config.setevictionpolicyclassname("org.apache.commons.pool2.impl.defaultevictionpolicy");

//是否啟用pool的jmx管理功能, 預設true

config.setjmxenabled(true);

//mbean objectname = new objectname("org.apache.commons.pool2:type=genericobjectpool,name=" + "pool" + i); 默 認為"pool", jmx不熟,具體不知道是幹啥的...預設就好.

config.setjmxnameprefix("pool");

//是否啟用後進先出, 預設true

config.setlifo(true);

//最大空閒連線數, 預設8個

config.setmaxidle(8);

//最大連線數, 預設8個

config.setmaxtotal(8);

//獲取連線時的最大等待毫秒數(如果設定為阻塞時blockwhenexhausted),如果超時就拋異常, 小於零:阻塞不確定的時間, 預設-1

config.setmaxwaitmillis(-1);

//逐出連線的最小空閒時間 預設1800000毫秒(30分鐘)

config.setminevictableidletimemillis(1800000);

//最小空閒連線數, 預設0

config.setminidle(0);

//每次逐出檢查時 逐出的最大數目 如果為負數就是 : 1/abs(n), 預設3

config.setnumtestsperevictionrun(3);

//物件空閒多久後逐出, 當空閒時間》該值 且 空閒連線》最大空閒數 時直接逐出,不再根據minevictableidletimemillis判斷 (預設逐出策略)

config.setsoftminevictableidletimemillis(1800000);

//在獲取連線的時候檢查有效性, 預設false

config.settestonborrow(false);

//在空閒時檢查有效性, 預設false

config.settestwhileidle(false);

//逐出掃瞄的時間間隔(毫秒) 如果為負數,則不執行逐出執行緒, 預設-1

config.settimebetweenevictionrunsmillis(-1);

jedispool pool = new jedispool(config, "localhost",);

int timeout=3000;

new jedissentinelpool(master, sentinels, poolconfig,timeout);//timeout 讀取超時

#最大活動物件數   

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

redis之jedis命令綜合

jedis.set hello worl 插入值 system.out.println hellor jedis.get hello 取值 redis中的列表 rpush 將給定值推入列表的右端 lrange 獲取列表在給定範圍上的所有值 lindex 獲取列表在給定位置上的單個元素 lpop 從列...

Redis 之Jedis和Lettuce客戶端

lettuce 和 jedis 的定位都是redis的client。jedis 當多執行緒使用同乙個連線時,是執行緒不安全的。所以要使用連線池,為每個jedis例項分配乙個連線。lettuce 基於netty的,連線例項 statefulredisconnection 可以在多個執行緒間併發訪問,因...

Redis(五)之整合Jedis與Spring

思路 建立乙個redis操作的介面。分別建立兩個實現類對應redis 的單機版和集群版。當使用單機版redis時,配置單機版的實現類,當使用集群版本的時候,配置集群版的實現類。redis客戶端介面,在這裡新增常用方法 public inte ce jedisclient redis客戶端單機版實現類...