配置文件和配置类

@Data
@Configuration
@ConfigurationProperties("jedis-config")
public class JedisConfigure { @Value("maxtotal")
private String maxTotal;
@Value("maxidle")
private String maxIdle;
@Value("minidle")
private String minIdle;
@Value("host")
private String host;
@Value("port")
private String port;
@Value("nodes")
private Set<String> nodes;
@Value("master-name")
private String masterName;
@Value("timeout")
private String timeout;
}
//配置文件 放在application.yml
jedis-config:
maxtotal: 100
host: 127.0.0.1
port: 6379
maxidle: 100
minidle: 0
master-name: mymaster
nodes:
- 127.0.0.1:7001
- 127.0.0.1:7002
- 192.168.1.98:7003
- 192.168.1.98:7004
- 192.168.1.20:7005
- 192.168.1.20:7006

  一、定义jedis接口

public interface IJedisService {

    /**
* 获取Jedis连接
* @return JedisCommands
*/
JedisCommands getJedis(); /**
* 释放连接
* @param jedis
*/
void jedisClose(JedisCommands jedis); /**
* 关闭连接池
*/
void jedisPoolClose();
}

  二、定义IJedisService的实现类

@EnableConfigurationProperties(JedisConfigure.class)
public class AbstractRedisService implements IJedisService { Pool<Jedis> jedisPool; @Autowired
private JedisConfigure jedisConfigure; /**
* jedis连接池配置类
*/
public GenericObjectPoolConfig jedisPoolConfig = new GenericObjectPoolConfig(); /**
* 初始化Jedis连接池配置
*/
@PostConstruct
public void initJedisPoolConfig() { jedisPoolConfig.setMaxTotal(Integer.parseInt(jedisConfigure.getMaxTotal()));
jedisPoolConfig.setMaxIdle(Integer.parseInt(jedisConfigure.getMinIdle()));
jedisPoolConfig.setMinIdle(Integer.parseInt(jedisConfigure.getMinIdle()));
jedisPoolConfig.setJmxEnabled(true);
jedisPoolConfig.setBlockWhenExhausted(true);
jedisPoolConfig.setTestOnBorrow(true);
jedisPoolConfig.setTestOnReturn(true);
jedisPoolConfig.setMaxWaitMillis(-1);
} /**
* 初始化线程池
* 根据Class类型初始化
* @param clazz
* @return
*/
public void initJedisPool(Class clazz) { //Single
if (JedisPool.class.getName().equals(clazz.getName()))
jedisPool = new JedisPool(jedisPoolConfig, jedisConfigure.getHost(),
Integer.parseInt(jedisConfigure.getPort()), 100000);
//Sentinel
if (JedisSentinelPool.class.getName().equals(clazz.getName()))
jedisPool = new JedisSentinelPool(jedisConfigure.getMasterName(),
jedisConfigure.getNodes(), jedisPoolConfig, 100000); } @Override
public JedisCommands getJedis() {
Jedis jedis = jedisPool.getResource();
return jedis;
} @Override
public void jedisClose(JedisCommands jedis) { jedisPool.returnResource((Jedis) jedis);
} @Override
public void jedisPoolClose() {
if (!jedisPool.isClosed()) jedisPool.close();
}
}

  三、单机模式的具体实现

public class JedisSingleService extends AbstractRedisService {

    @PostConstruct
private void loadJedisPool() {
super.initJedisPool(JedisPool.class);
}
}

  四、Sentinel模式的具体实现

public class JedisSentinelService extends AbstractRedisService {

    @PostConstruct
private void loadJedisPool() {
super.initJedisPool(JedisSentinelPool.class);
}
}

  五、Cluster模式的具体实现

@Slf4j
@EnableConfigurationProperties(JedisConfigure.class)
public class JedisClusterService extends AbstractRedisService { @Autowired
private JedisConfigure jedisConfigure; JedisCluster jedis; /**
* 初始化配置
*/
@PostConstruct
private void initJedisCluster() { //初始化一般配置
super.initJedisPoolConfig(); //初始化JedisCluster
Set<HostAndPort> clusterHostMap = Sets.newHashSet();
initHostMap(clusterHostMap, jedisConfigure.getNodes());
jedis = new JedisCluster(clusterHostMap, jedisPoolConfig);
} /**
* 节点转换
*
* @param clusterHostMap
* @param nodes
*/
private void initHostMap(Set<HostAndPort> clusterHostMap, Set<String> nodes) {
if (clusterHostMap == null)
return;
try {
for (String node : nodes) { log.info("初始化Redis-Cluster集群 --- [{}]", node);
String[] nodeInfo = node.split(":"); String ip = nodeInfo[0];
Integer port = Integer.parseInt(nodeInfo[1]); HostAndPort hostAndPort = new HostAndPort(ip, port);
clusterHostMap.add(hostAndPort);
}
} catch (Exception e) {
throw new RuntimeException("redis-->Cluster集群节点配置异常");
}
} @Override
public JedisCommands getJedis() {
return jedis;
} @Override
public void jedisClose(JedisCommands jedis) { try {
((JedisCluster) jedis).close();
} catch (IOException e) {
e.printStackTrace();
log.error("Redis-Cluster Close失败 --- [{}]", e.getMessage());
}
}
}

  六、注入Bean

@Bean
public IJedisService redisSingleJedisService() { return new JedisSingleService(); } @Bean
IJedisService redisSentinelService() { return new JedisSentinelService(); } @Bean
IJedisService redisClusterService() { return new JedisClusterService(); }

  

Jedis整合单机、Sentinel和Cluster模式的更多相关文章

  1. SpringBoot连接Redis (Sentinel模式&Cluster模式)

    一.引入pom <dependency> <groupId>org.springframework.boot</groupId> <artifactId> ...

  2. 【Redis】Redis学习(二) master/slave、sentinel、Cluster简单总结

    项目中用到Redis,所以准备学习一下,感觉Redis的概念还是很多的,什么主从模式.sentinel模式.集群模式的,一下子都晕了,我觉得还是有必要先理清这些基本概念再说. 一.单节点实例 单节点实 ...

  3. Redis 部署方式(单点、master/slaver、sentinel、cluster) 概念与区别

    转载自 https://blog.csdn.net/java_zyq/article/details/83818341 在K8S上部署Redis集群时突然遇到一个(sentinel哨兵模式)概念,感觉 ...

  4. Spring Boot集成Redis集群(Cluster模式)

    目录 集成jedis 引入依赖 配置绑定 注册 获取redis客户端 使用 验证 集成spring-data-redis 引入依赖 配置绑定 注册 获取redis客户端 使用 验证 异常处理 同样的, ...

  5. Redis 5.0.7 讲解,单机、集群模式搭建

    Redis 5.0.7 讲解,单机.集群模式搭建 一.Redis 介绍 不管你是从事 Python.Java.Go.PHP.Ruby等等... Redis都应该是一个比较熟悉的中间件.而大部分经常写业 ...

  6. Redis集群-Cluster模式

    我理解的此模式与哨兵模式根本区别: 哨兵模式采用主从复制模式,主和从数据都是一致的.全量数据: Cluster模式采用数据分片存储,对每个 key 计算 CRC16 值,然后对 16384 取模,可以 ...

  7. Spark基本工作流程及YARN cluster模式原理(读书笔记)

    Spark基本工作流程及YARN cluster模式原理 转载请注明出处:http://www.cnblogs.com/BYRans/ Spark基本工作流程 相关术语解释 Spark应用程序相关的几 ...

  8. benchmark pm2的cluster模式发布web app的性能与相关问题解决方法

    pm2以cluster集群方式发布app,可以高效地利用多核cpu,有效提升吞吐量.在上周对公司的redmine服务器进行性能调优后,深感ruby on rails的性能低下,这次测试nodejs的s ...

  9. Greenplum源码编译安装(单机及集群模式)完全攻略

    公司有个项目需要安装greenplum数据库,让我这个gp小白很是受伤,在网上各种搜,结果找到的都是TMD坑货帖子,但是经过4日苦战,总算是把greenplum的安装弄了个明白,单机及集群模式都部署成 ...

随机推荐

  1. 使用PHP curl模拟浏览器抓取网站信息

    curl是一个利用URL语法在命令行方式下工作的文件传输工具.curl是一个利用URL语法在命令行方式下工作的文件传输工具.它支持很多协议:FTP, FTPS, HTTP, HTTPS, GOPHER ...

  2. Invoking destroy method 'close' on bean with name 'dataSource'

    Invoking destroy method 'close' on bean with name 'dataSource' Spring与Mybatis整合时出现的问题,找了一晚上结果是一个属性写错 ...

  3. Openstack 中的消息总线 & AMQP

    目录 目录 消息总线 消息总线的原理 AMQP 消息总线 Openstack 采用了面向服务的开发模式(有别于面向对象和面向过程),需要我们去考虑各个服务之间和各项目之间是如何传递消息的. Restf ...

  4. (转载) 深入理解ES6箭头函数的this以及各类this面试题总结

    声明:本文转载自 https://blog.csdn.net/yangbingbinga/article/details/61424363 ES6中新增了箭头函数这种语法,箭头函数以其简洁性和方便获取 ...

  5. java中trim()方法是用来干什么的?

    trim()的作用是去掉字符串两端的多余的空格,注意,是两端的空格,且无论两端的空格有多少个都会去掉,当然 中间的那些空格不会被去掉,如: String s = "  a s f g     ...

  6. 20140725 快速排序时间复杂度 sTL入门

    1.快速排序的时间复杂度(平均时间复杂度为) 数组本身就有序时,效果很差为O(n^2) 2.STl入门 (1) C++内联函数(inline)和C中宏(#define)区别 内联函数有类型检查,宏定义 ...

  7. 通过字体代替图片优化,如何使用Font Awesome字体图标?

    博客搬迁,给你带来的不便敬请谅解! http://www.suanliutudousi.com/2017/10/17/%E9%80%9A%E8%BF%87%E5%AD%97%E4%BD%93%E4%B ...

  8. java MySQl数据库连接

    <%@ page import="java.sql.Connection" %> <%@ page import="java.sql.DriverMan ...

  9. jmeter-测试webservice接口

    测试webservice接口(soap类型接口) 一.webservice协议的本质 一个经过封装的post类型的HTTP请求 Web service一般就是用SOAP协议通过HTTP来调用它,其实他 ...

  10. linux 7 系统查询相关

    今天 领导让我整理一下查询关于系统信息的一些命令,查找并验证了之后,我发上来给大家分享一下. 1. #uname –a显示电脑及操作系统信息2. #cat /proc/version查看正在运行的内核 ...