redis集群操作类

创作不易,请勿抄袭,转载请注明出处。如有疑问,请加微信 wx15151889890,谢谢。
[本文链接:]https://blog.csdn.net/wx740851326/article/details/83744118
话不多说,直接上代码:

import java.util.HashSet;
import java.util.Properties;
import java.util.Set;

import org.apache.commons.pool2.impl.GenericObjectPoolConfig;

import redis.clients.jedis.HostAndPort;
import redis.clients.jedis.JedisCluster;
/**
 * define redis handlers
 * 
 * @author dmvoishi
 * @since  20181024
 * @category initRedisCluster addNodes getJedisCluster
 */
public class RedisUtil {

	public static JedisCluster initRedisCluster(Properties prop) {
		// 根据配置文件实例化一个集群
		GenericObjectPoolConfig poolConfig = new GenericObjectPoolConfig();
		String NODE_LIST = prop.getProperty("NODE_LIST").trim();
		Set<HostAndPort> nodes = addNodes(NODE_LIST);

		String MAX_WAIT = prop.getProperty("MAX_WAIT");
		String MAX_IDLE = prop.getProperty("MAX_IDLE");
		String TIME_OUT = prop.getProperty("TIME_OUT").trim();
		String MAX_ACTIVE = prop.getProperty("MAX_ACTIVE");

		poolConfig.setMaxTotal(Integer.parseInt(MAX_ACTIVE));
		poolConfig.setMaxIdle(Integer.parseInt(MAX_IDLE));
		poolConfig.setMaxWaitMillis(Integer.parseInt(MAX_WAIT));
		poolConfig.setJmxEnabled(true);
		poolConfig.setTestWhileIdle(true);
		poolConfig.setTestOnBorrow(true);
		poolConfig.setTestOnReturn(true);
		JedisCluster jedisCluster = new JedisCluster(nodes,
				Integer.valueOf(TIME_OUT), poolConfig);
		return jedisCluster;
	}

	private static Set<HostAndPort> addNodes(String nodes) {
		// TODO Auto-generated method stub
		Set<HostAndPort> nodeList = new HashSet<HostAndPort>();
		String[] node = nodes.split(",");
		for (int i = 0; i < node.length; i++) {
			if (null != node[i]) {
				String[] url = node[i].split(":");
				nodeList.add((new HostAndPort(url[0].trim(), Integer
						.valueOf(url[1]))));
			}
		}
		return nodeList;
	}

	public static JedisCluster getJedisCluster() {
		String redisConfigPath = "hdfs:///user/hdfs/redis.cfg";
//		String path = "C:/config/redis.cfg";
		Properties redisProp = CommonUtils
				.getPropertiesFromHDFS(redisConfigPath);
//		 .getPropertiesFromLocal(path);
		JedisCluster jedisCluster = RedisUtil.initRedisCluster(redisProp);
		return jedisCluster;
	}
}

文内用到的一些通用工具类,请翻阅鄙人的其他文章。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值