码上敲享录 > redis数据库常见问题 > JedisPool连接池的用法

JedisPool连接池的用法

上一章章节目录下一章 2018-07-26已有4175人阅读 评论(0)

JedisPool连接池的用法

解决方法:

直接上原码,直接复制就可以使用,但要下载jedis-2.9.0.jar,项目启动时初始化initPool()方法即可,getJedis()获取Jedis操作数据库,close()把Jedis返还给连接池。

import java.util.ArrayList;

import java.util.List;

import java.util.Map;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import redis.clients.jedis.Jedis;

import redis.clients.jedis.JedisPool;

import redis.clients.jedis.JedisPoolConfig;

import redis.clients.jedis.exceptions.JedisException;

public class Redis {

private static final Logger logger = LoggerFactory.getLogger(Redis.class);

private static JedisPool jedisPool = null;

public void initPool(){

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(10);

//最大连接数, 默认8个

config.setMaxTotal(50);

//获取连接时的最大等待毫秒数(如果设置为阻塞时BlockWhenExhausted),如果超时就抛异常, 小于零:阻塞不确定的时间,  默认-1

config.setMaxWaitMillis(30000);

//资源池中资源最小空闲时间(单位为毫秒),达到此值后空闲资源将被移除  默认1800000毫秒(30分钟)

config.setMinEvictableIdleTimeMillis(60000);

//最小空闲连接数, 默认0

config.setMinIdle(0);

//每次逐出检查时 逐出的最大数目 如果为负数就是 : 1/abs(n), 默认3

config.setNumTestsPerEvictionRun(3);

//对象空闲多久后逐出, 当空闲时间>该值 且 空闲连接>最大空闲数 时直接逐出,不再根据MinEvictableIdleTimeMillis判断  (默认逐出策略)

config.setSoftMinEvictableIdleTimeMillis(1800000);

//在获取连接的时候检查有效性, 默认false

config.setTestOnBorrow(false);

//是否开启空闲资源监测, 默认false

config.setTestWhileIdle(true);

//空闲资源的检测周期(单位为毫秒) 如果为负数,则不运行逐出线程, 默认-1

config.setTimeBetweenEvictionRunsMillis(-1);

jedisPool = new JedisPool(config, RedisConfig.IP, RedisConfig.PORT, 3000, RedisConfig.PASSWORD);

}


public synchronized static Jedis getJedis() {

try {

if (jedisPool != null) {

Jedis resource = jedisPool.getResource();

return resource;

} else {

return null;

}

} catch (Exception e) {

e.printStackTrace();

return null;

}

}


public static void close(final Jedis jedis) {

if (jedis != null) {

jedis.close();

}

}

}


本文地址:http://yayihouse.com/yayishuwu/chapter/1361

0

有建议,请留言!

  • *您的姓名:

  • *所在城市:

  • *您的联系电话:

    *您的QQ:

  • 咨询问题:

  • 提 交