SpringBoot (六) :springboot与redis集群

上一篇写了springboot与mongo的整合,那么这次就写一下springboot与redis的结合,这里使用的是redis集群模式(主从),主从环境的搭建,请参考
redis集群搭建
搭建完redis集群环境后,开始springboot之旅

1、redis介绍

redis的介绍及应用场景参考 redis介绍

2、项目构建

我们还是从redis项目构建开始说起,首先还是进入的spring官网,
从这里开始构建项目,如下图

11.png

当然也可以自己添加pom文件,如下

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

3、添加配置文件

application.properties中

#-----------------------
# start redis cluster
jedis.cluster.nodesString= 103.45.12.176:7000,47.88.221.76:7000,103.45.12.176:7001,47.88.221.76:7001,103.45.12.176:7002,47.88.221.76:7002
jedis.cluster.testWhileIdle=true
jedis.cluster.connectionTimeout=60
jedis.cluster.soTimeout=60
jedis.cluster.maxAttempts=1000
jedis.cluster.password=12597758
# end redis cluster config
#---------------------------------

4、jedis配置类的编写

这里是核心jedisCluster这个bean的创建

@Configuration
@ConfigurationProperties(prefix = "jedis.cluster")
public class JedisClusterConfig {
    private String nodesString;
    private Boolean testWhileIdle;
    private Integer connectionTimeout;
    private Integer soTimeout;
    private Integer maxAttempts;
    private String  password;
    public Boolean getTestWhileIdle() {
        return testWhileIdle;
    }

    public void setTestWhileIdle(Boolean testWhileIdle) {
        this.testWhileIdle = testWhileIdle;
    }

    public Integer getConnectionTimeout() {
        return connectionTimeout;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public void setConnectionTimeout(Integer connectionTimeout) {
        this.connectionTimeout = connectionTimeout;
    }

    public Integer getSoTimeout() {
        return soTimeout;
    }

    public void setSoTimeout(Integer soTimeout) {
        this.soTimeout = soTimeout;
    }

    public Integer getMaxAttempts() {
        return maxAttempts;
    }

    public void setMaxAttempts(Integer maxAttempts) {
        this.maxAttempts = maxAttempts;
    }

    public String getNodesString() {
        return nodesString;
    }

    public void setNodesString(String nodesString) {
        this.nodesString = nodesString;
    }

    @Bean
    public JedisCluster jedisCluster() {

        String[] nodes = nodesString.split(",");
        Set<HostAndPort> nodeSet = new HashSet<HostAndPort>(nodes.length);

        for (String node : nodes) {
            String[] nodeAttrs = node.trim().split(":");
            HostAndPort hap = new HostAndPort(nodeAttrs[0], Integer.valueOf(nodeAttrs[1]));
            nodeSet.add(hap);
        }
        JedisPoolConfig poolConfig = new JedisPoolConfig();
        // TODO:password and poolconfig
        JedisCluster jc = new JedisCluster(nodeSet, connectionTimeout, soTimeout, maxAttempts,password, poolConfig);
        return jc;
    }
}

5、通用接口的编写

经过这几篇的博客,可能也发现很多接口的定义,然后由不同的业务类去实现,面向接口的编程也是经历过近期的一个项目才有了比较深的理解,这些都是跟朱哥和军哥学习的,代码编写的规范,对于一个程序员来说,越早养成越好

public interface NoSqlClient<T> {
    void set(final String key, final T value);

    void set(String key, T value, Long expiry);

    <T> boolean exist(Class<T> clazz, String key);

    T get(final String key, Class<T> clazz);

    <T> void delete(String key);

    <T> void hashSet(String key, String hashKey, T hashValue);

    Object hashGet(String key, String hashKey, Class<?> hashValueClazz);
}

6、接下来是jedis接口的实现

@Service
public class JedisClusterClient<T> implements NoSqlClient<T> {
    protected final Logger logger = LoggerFactory.getLogger(this.getClass());

    @Autowired
    private JedisCluster jedisCluster;
    public void set(String key, T value){
        logger.info("-------------"+jedisCluster);
        jedisCluster.set(key,JSON.toJSONString(value,true));
    }

    @Override
    public void set(String key, T value, Long expiry) {

    }

    @Override
    public <T1> boolean exist(Class<T1> clazz, String key) {
        checkRedisKey(key);
        return jedisCluster.exists(key);
    }

    @Override
    public T get(String key, Class<T> clazz) {
        checkRedisKey(key);
        String value = jedisCluster.get(key);
        return JSON.parseObject(value, clazz);
    }

    @Override
    public <T1> void delete(String key) {
        checkRedisKey(key);
        jedisCluster.del(key);
    }

    @Override
    public <T1> void hashSet(String key, String hashKey, T1 hashValue) {
        checkRedisKey(key);
        jedisCluster.hset(key, hashKey, JSON.toJSONString(hashValue));
    }

    @Override
    public Object hashGet(String key, String hashKey, Class<?> hashValueClazz) {
        return null;
    }
    /**
     * 检查Redis参数
     *
     * @param key
     * @param value
     * @return
     */
    private String checkRedisNoSqlSupport(final String key, final T value) {
        checkRedisKey(key);
        if (value == null)
            throw new RedisException("value is null!");
        String stringValue = null;
        try {
            stringValue = JSON.toJSONString(value,true);
        } catch (JSONException e) {
            throw new RedisException("value toJSONString exception!");
        }
        if (StringUtils.isEmpty(stringValue))
            throw new RedisException("value is null!");
        return stringValue;
    }

    /**
     * 检查Redis key,redis key 长度建议不要超过1M,redis支持512M
     * @param key
     */
    private void checkRedisKey(final String key) {
        if (StringUtils.isEmpty(key))
            throw new RedisException("key is null!");
        if (key.length() > 1000000L)
            throw new RedisException("length of key greater than 1M!");
    }
}

这里我只写了几个基础的核心配置,包括一些异常的处理,这里都没有贴出代码,当然代码在文章最后也会给出,不必担心

7、业务dao的实现

不同的业务只需继承上面的类即可

@Component
public class UserInfoCacheDao extends JedisClusterClient<UserInfo> {
    public void setUserInfo(UserInfo userInfo){
        super.set("lessons.user:1",userInfo);
    }
}

这里同样也是只写了一个set方法

8、单元测试

@RunWith(SpringJUnit4ClassRunner.class)
@SpringBootTest
public class UserInfoCacheDaoTest {
    @Autowired
    private UserInfoCacheDao userInfoCacheDao;
    @Test
    public void setUserInfo() throws Exception {
        UserInfo userInfo = new UserInfo();
        userInfo.setAge(12);
        userInfo.setId(1000l);
        userInfo.setName("admin");
        userInfo.setNickname("管理员");
        userInfo.setPassword("123445");
        userInfoCacheDao.setUserInfo(userInfo);
    }

}

添加完成后,去查看发现,已经有已经生成。

github
中lessons-6

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,544评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,430评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,764评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,193评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,216评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,182评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,063评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,917评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,329评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,543评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,722评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,425评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,019评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,671评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,825评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,729评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,614评论 2 353

推荐阅读更多精彩内容

  • 1 Redis介绍1.1 什么是NoSql为了解决高并发、高可扩展、高可用、大数据存储问题而产生的数据库解决方...
    克鲁德李阅读 5,291评论 0 36
  • 本文档翻译自 http://redis.io/topics/cluster-tutorial 。 本文档是 Red...
    会跳舞的机器人阅读 66,928评论 2 21
  • 开心消消乐是一款休闲而小娱乐的可单机手游,相对来说,在闲暇时,是个比较好的消遣,游戏以清新而萌萌的画风为主,甚得青...
    game花生仙子阅读 605评论 10 7
  • 都说梦是反的。 看梦的解析看关于梦的鸡汤 都不能给我一个答案 关于你是否会拉住我的手 是否会停止我的情感消耗或者重...
    卣足阅读 428评论 0 0
  • 看完了拜拜啦肉肉 突然发现喜欢的综艺节目都收官了 今天我也送签了 慢慢的发现很多事情都是要板上钉钉了 自己的压力也...
    nicole_e阅读 203评论 0 0