1.Java客户端示例:
public class JedisManager { /** * jedis连接池,维持jedis连接 */ private static JedisManager jedisManager = new JedisManager(); private static JedisSentinelPool jedisSentinelPool = null; //初始化jedissentinelpool static{ JedisPoolConfig config = new JedisPoolConfig(); Set<String> sentinels = new HashSet<String>(); for (String sentinel:Constants.SENTINELS){ sentinels.add(sentinel); } config.setMaxIdle(Constants.MAX_IDLE); config.setMaxTotal(Constants.MAX_TOTAL); config.setMaxWaitMillis(Constants.MAX_WAITMILLIS); config.setTestOnBorrow(true); config.setTestOnReturn(true); config.setTestWhileIdle(true); String masterName = Constants.Master_Name; int timeout = Constants.TIME_OUT; String password = Constants.PASSWORD; int database = Constants.DBINDEX; jedisSentinelPool = new JedisSentinelPool(masterName, sentinels, config, timeout, password, database); } private JedisManager(){ } public static JedisManager getInstance(){ return jedisManager; } * 获取jedis链接 * * @return */ public Jedis getJedisResource() { Jedis jedis = null; try { jedis = jedisSentinelPool.getResource(); } catch (Exception e) { e.printStackTrace(); LOGGER.error("redis server error."); } return jedis; } /** * 释放jedis链接 * * @param jedis */ public void returnJedisResource(Jedis jedis) { jedisSentinelPool.returnResource(jedis); } }
2.参数说明:
//连接耗尽时是否阻塞, 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);
3.redis相关资料汇总:
http://blog.nosqlfan.com/html/3537.html