这是使用jedis分别连接redis和redis集群
redis单机版:
连接redis
JedisPoolConfig config = new JedisPoolConfig();
// 最大连接数
config.setMaxTotal(maxActive);
// 最大空闲连接数
config.setMaxIdle(maxIdle);
//连接的最小空闲时间,达到此值后该空闲连接可能会被移除(还需看是否已达最大空闲连接数)
config.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
// 空闲连接检测的周期(单位毫秒);如果为负值,表示不运行检测线程;
config.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
JedisPool jedisPool = null;
// 当redis 的密码不为空时
if (StringUtils.isNotBlank(password)) {
jedisPool = new JedisPool(config, host, port, timeout, password);
} else {
jedisPool = new JedisPool(config, host, port, timeout);
}
使用:
// 此jedis就是操作redis的对象,具体操作可看对应的api
jedis = jedisPool.getResource();
jedis.set(key, value);
redis集群版:
连接redis集群
// nodesParam就是配置文件的node集群节点,比如127.0.0.1:6379,127.0.0.1:6380, 中间用逗号或其他分隔符分隔
String[] serverArray = nodesParam.split(",");
Set<HostAndPort> nodes = new HashSet<HostAndPort>();
for(String ipPort: serverArray){
String[] ipPortPair = ipPort.split(":");
nodes.add(new HostAndPort(ipPortPair[0].trim(),Integer.valueOf(ipPortPair[1].trim())));
}
GenericObjectPoolConfig genericObjectPoolConfig = new GenericObjectPoolConfig();
// 最大空闲连接数
genericObjectPoolConfig.setMaxIdle(maxIdle);
// 最大连接数
genericObjectPoolConfig.setMaxTotal(maxTotal);
// 最小空闲连接数
genericObjectPoolConfig.setMinIdle(minIdle);
// 当连接池资源耗尽时,等待时间,超出则抛异常,默认为-1即永不超时
genericObjectPoolConfig.setMaxWaitMillis(redisProperties.getMaxWait());
JedisCluster jedisCluster = null;
String password = redisProperties.getPassword();
if(StringUtils.isNotBlank(password)){
jedisCluster = new JedisCluster(nodes,redisProperties.getTimeout(),redisProperties.getMaxWait(),redisProperties.getMaxAttempts(),password,genericObjectPoolConfig);
}else{
jedisCluster = new JedisCluster(nodes,redisProperties.getTimeout(),redisProperties.getMaxWait(),redisProperties.getMaxAttempts(),genericObjectPoolConfig);
}
使用 : 直接使用上方的jedisCluster进行操作即可