jedis所使用的單節點模式,整合spring配置如下:
<bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
<property name="maxTotal" value="600" />
<property name="maxIdle" value="300" />
<property name="maxWaitMillis" value="1000" />
<property name="testOnBorrow" value="true" />
</bean>
<bean id="jedisPool" class="redis.clients.jedis.JedisPool">
<constructor-arg index="0" ref="jedisPoolConfig" />
<constructor-arg index="1" value="127.0.0.1" />
<constructor-arg index="2" value="6379" type="int" />
<constructor-arg index="3" value="60000" type="int" />
<constructor-arg index="4" value="123456"/>
</bean>
工具代碼如下:
@Resource
private JedisPool jedisPool;
@Override
public Jedis getJedis() {
return jedisPool.getResource();
}
業務代碼如下:
for(int i = 2000; i<3000; i++) {
Jedis jedis = redisDao.getJedis();
jedis.set("user:" + i, jedis.toString());
System.out.println(jedis);
set.add(jedis.toString());
}
在上面的程式碼中,當循環到600次的時候,就會報出拿不到連接的錯誤,而600恰好是配置中的連接個數;並且jedis連接不會在使用結束後進行釋放(因為報錯後,再次請求這個方法,連一個連線都拿不到了)。
如果在程式碼的循環中加入
jedis.close();
則效果就不一樣了,可以循環結束,並且列印的jedis物件是同一個連接位址。
這種情況下,要么在業務代碼層使用結束後進行關閉,要把jedis所有的方法都單獨進行一次封裝,在封裝的代碼裡面進行關閉連接,難道沒有其他好的辦法了嗎?