金麟岂是池中物,一遇风云便化龙
前言
微服务如今的发展趋已然是势不可挡,并且业内已经有Dubbo、SpringCloud等优秀的开源框架,可以说发展的已经是非常成熟了,所以决定顺应技术发展浪潮,放弃老旧而臃肿的SSM,转而搭建以SpringCloud为基础的微服务应用。
通过Redis实现缓存与应用集群间的Session共享是很成熟的应用缓存层解决方案,所以在框架搭建过程中必然是需要整合Redis,并且通过Redis的Sentinel实现了Redis的高可用。在整合Redis的过程中始终没有找到比较好用的解决方案,看过很多博客,发现都不是自己想要的,所以索性决定自己来写一个,仅供参考。
依赖注入
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
项目路径如下
redis.properties
虽然SpringCloud简化项目配置,但是绝对不是要求研发人员在项目中不可以使用配置,还是那句话约定大于配置,习惯大于约定。所以我们在项目中建立redis.properties用于配置Redis服务。
redis.nodes=192.168.1.205:26379,192.168.1.206:26379,192.168.1.207:26379
redis.masterName=artisanRedis
redis.password=abc123456
redis.maxTotal=10000
redis.maxIdle=100
redis.minIdle=50
redis.timeout=30000
RedisConfig
SpringCloud给我们带了很多开箱即用的工具,能够让我们的代码更加的优雅。@ConfigurationProperties 让我们不再为读取配置文件而感到烦恼,在SpringBoot 1.5+后需要配合@PropertySource使用,RedisConfig.java便优雅的读取了Redis配置文件。
package com.artisan.redis.config;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Component;
/**
*
* @author Fire Monkey
* @date 2018/3/12 下午6:25
* Redis配置文件
*
*/
@Component
@PropertySource("classpath:conf/redis.properties")
@ConfigurationProperties(prefix = "redis")
public class RedisConfig {
/**
* 节点名称
*/
private String nodes;
/**
* Redis服务名称
*/
private String masterName;
/**
* 密码
*/
private String password;
/**
* 最大连接数
*/
private int maxTotal;
/**
* 最大空闲数
*/
p