springboot整合redisCluster集群(springboot整合redisCluster集群)

springboot整合redisCluster集群:(前提redis集群已经搭建好。windows上搭建redis集群参考:https://www.cnblogs.com/super-chao/p/9329018.html。linux上搭建redis集群步骤和windows上搭建redis集群一致)

1.引入springboot和redis的相关jar包:

<parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.7.RELEASE</version>
    </parent>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
            <exclusions>
                <exclusion>
                    <artifactId>spring-aop</artifactId>
                    <groupId>org.springframework</groupId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <artifactId>spring-aop</artifactId>
                    <groupId>org.springframework</groupId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

2.创建application.yml配置文件并配置redis集群:

#server:
#  port: 8762
spring:
  application:
    name: redis
  #redis配置
  redis:
#    host: 192.168.1.100
#    port: 6385
    pool:
      max-idle: 100
      min-idle: 1
      max-active: 1000
      max-wait: -1
    database: 0
    timeout: 100000
    cluster:
      nodes:
        #地址要和redis配置中bind地址一致
        - 127.0.0.1:6379
        - 127.0.0.1:6380
        - 127.0.0.1:6381
        - 127.0.0.1:6382
        - 127.0.0.1:6383
        - 127.0.0.1:6384

3.redis工具类,RedisClusterService:

package com.springbootrediscluster.redis;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Service;

import java.util.concurrent.TimeUnit;

@Service
public class RedisClusterService {
    @Autowired
    private StringRedisTemplate stringRedisTemplate;

    public void setStr(String key, String value) {
        setStr(key, value, null);
    }

    public void setStr(String key, String value, Long time) {
        /*stringRedisTemplate.opsForValue().set(key, value);
        if (time != null)
            stringRedisTemplate.expire(key, time, TimeUnit.SECONDS);*/
        stringRedisTemplate.opsForValue().set(key,value);
        if(time != null){
            stringRedisTemplate.expire(key, time, TimeUnit.SECONDS);
        }
        /*if(time != null){
            jedisCluster.expire(key,(int) (time/1000));
        }*/
    }

    public Object getKey(String key) {
        /*return redisTemplate.opsForValue().get(key);*/
        return stringRedisTemplate.opsForValue().get(key);
    }

    public void delKey(String key) {
        /*stringRedisTemplate.delete(key);*/
        stringRedisTemplate.delete(key);
    }
}

4.controller类,IndexController:

package com.springbootrediscluster.controller;

import com.springbootrediscluster.redis.RedisClusterService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

/**
 * Created by Administrator on 2021/8/15.
 */
@Controller
public class IndexController {
    @Autowired
    private RedisClusterService redisClusterService;

    @RequestMapping("/setRedis")
    @ResponseBody
    public String setRedis(String key, String value) {
        redisClusterService.setStr(key, value);
        return "success";
    }

    @RequestMapping("/getKey")
    @ResponseBody
    public Object getKey(String key){
        Object result = redisClusterService.getKey(key);
        return result == null ? "缓存中没有该数据" : result;
    }

    @RequestMapping("/delStringKey")
    @ResponseBody
    public String reStrRedis(String key){
        redisClusterService.delKey(key);
        return "success";
    }
}

5.springboot的app启动类App:

package com.itmayiedu.app;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.ComponentScan;

@ComponentScan("com.itmayiedu.**")
@EnableAutoConfiguration
public class App {
    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }
}

 

6.测试:

 

 

 

 也可在dos命令窗口查看值,或者通过RedisClient可视化工具查看redis的值。

至此,springboot整合redisCluster集群完成。项目中可直接使用工具类RedisClusterService(可自行重构)对redisCluster集群操作。

 

posted @ 2021-08-15 14:42  super超人  阅读(5568)  评论(0编辑  收藏  举报