SpringBoot 配置redis集群

导入依赖

<!--Springboot集成 Redis ,Springboot2.x默认是用Lettuce连接redis,Lettuce可伸缩,线程安全-->
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

配置applcation.yml

# redis 配置
redis:
  server:
    pattern: cluster
    nodes: 127.0.0.1:3000,127.0.0.1:3001,127.0.0.1:3002,127.0.0.1:3003,127.0.0.1:3004,127.0.0.1:3005
    password:
    maxIdle: 8
    minIdle: 4
    maxTotal: 8
    maxWaitMillis: 6000
    timeOut: 6000

方式一:redis(存储各种对象)

  (1).配置

@Configuration
public class RedisConfig {
    @Value("${redis.server.nodes}")
    private String redisServerNodes;

    @Value("${redis.server.password}")
    private String redisServerPassword;

    @Bean
    public RedisClusterConfiguration getRedisClusterConfiguration() {

        RedisClusterConfiguration redisClusterConfiguration = new RedisClusterConfiguration();

        String[] serverArray = redisServerNodes.split(",");
        Set<RedisNode> nodes = new HashSet<RedisNode>();
        for (String ipPort : serverArray) {
            String[] ipAndPort = ipPort.split(":");
            nodes.add(new RedisNode(ipAndPort[0].trim(), Integer.parseInt(ipAndPort[1])));
        }
        redisClusterConfiguration.setClusterNodes(nodes);
        RedisPassword pwd = RedisPassword.of(redisServerPassword);
        redisClusterConfiguration.setPassword(pwd);
        return redisClusterConfiguration;
    }

    //指定redisTemplate类型,如下为<String, Object>
    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<String, Object> template = new RedisTemplate();
        template.setConnectionFactory(redisConnectionFactory);
        // 使用JSON格式序列化对象,对缓存数据key和value进行转换
        Jackson2JsonRedisSerializer<Object> jacksonSeial = new Jackson2JsonRedisSerializer<>(Object.class);
        // 解决查询缓存转换异常的问题
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jacksonSeial.setObjectMapper(objectMapper);

        // 设置RedisTemplate模板API的序列化方式为JSON
        template.setDefaultSerializer(jacksonSeial);
        return template;
    }
}

 (2).使用

//1.指定存储类型
@Autowired
private RedisTemplate<String,Object> redisTemplate;
//2.未指定存储类型
@Autowired
private RedisTemplate redisTemplate;

//存储
redisTemplate.opsForValue().set(keyName, valueObject, Duration.ofXXX(n));
//Duration.ofNanos() 纳秒
//Duration.ofMillis() 毫秒
//Duration.ofSeconds() 秒
//Duration.ofMinutes() 分钟
//Duration.ofHours() 小时
//Duration.ofDays() 天

//查询
redisTemplate.opsForValue().get(keyName);

方式二:redission (常用于储存分布式锁)

(1).配置

@Configuration
public class RedissonConfig {

    @Value("${redis.server.pattern:single}")
    private String pattern;

    @Value("${redis.server.host:127.0.0.1}")
    private String host;

    @Value("${redis.server.nodes:1}")
    private List<String> nodes;

    @Value("${redis.server.port:6379}")
    private String port;

    @Value("${redis.server.password}")
    private String password;

    @Value("${redis.server.database:1}")
    private Integer database;


    @Bean
    @ConditionalOnProperty(prefix = "redis.server", name = "pattern", havingValue = "cluster")
    public RedissonClient clusterRedisClient() {
        Config config = new Config();
        ClusterServersConfig clusterServersConfig = config.useClusterServers();

        if (!StringUtils.isBlank(password)) {
            clusterServersConfig.setPassword(password);
        }
        // 集群状态扫描间隔时间,单位是毫秒
        clusterServersConfig.setScanInterval(2000);
        for (String node : nodes) {
            String url = "redis://" + node;
            clusterServersConfig.addNodeAddress(url);
        }
        RedissonClient redissonClient = Redisson.create(config);

        return redissonClient;
    }


    @Bean
    @ConditionalOnProperty(prefix = "redis.server", name = "pattern", havingValue = "single")
    public RedissonClient singleRedisClient() {
        Config config = new Config();
        SingleServerConfig singleServerConfig = config.useSingleServer();

        if (!StringUtils.isBlank(password)) {
            singleServerConfig.setPassword(password);
        }
        String url = "redis://" + host + ":" + port;
        singleServerConfig.setAddress(url);
        singleServerConfig.setDatabase(database);
        RedissonClient redissonClient = Redisson.create(config);

        return redissonClient;
    }
}

redis.server.name=cluster 集群模式

redis.server.name=single 单击模式

(2).使用

//锁工具封装
public class RedissionLockTools{ 
   
    @Autowired
    private static RedissonClient redissonClient;
    
    //加锁
    public static boolean lock(String lockName){
        //声明key对象
        String key = "LOCK_TITLE" + lockName;
        //获取锁对象
        RLock mylock = redissonClient.getLock(key);
        //加锁,并且设置锁过期时间3秒,防止死锁的产生  uuid+threadId
        mylock.lock(3, TimeUnit.SECONDS);
        //加锁成功
        return  true;
    }

    //锁的释放
    public static void unlock(String lockName) {
        //必须是和加锁时的同一个key
        String key = "LOCK_TITLE" + lockName;
        //获取所对象
        RLock mylock = redissonClient.getLock(key);
        //释放锁(解锁)
        mylock.unlock();
    }
}
public Object getUserById(User user) throws IOException{
    String lockName = "lockName01";
    //加锁
    RedissionLockTools.lock(lockName);
    //执行具体业务逻辑
    //~~~~~~~
    //执行具体业务逻辑
    //释放锁
    RedissionLockTools.unlock(lockName);
    //返回结果
    return result;
 }
  • 9
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在进行Spring Boot项目开发时,我们常常需要使用Redis作为缓存服务,而Redis集群则是为了满足高可用性和可扩展性而设计的。本文以Spring Boot2.0为例,介绍如何配置Redis集群。 一、引入redisson和lettuce连接池 在pom.xml文件中,我们需要引入redisson和lettuce连接池两个依赖: ``` <dependency> <groupId>org.redisson</groupId> <artifactId>redisson</artifactId> <version>3.11.6</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` 二、配置Redis集群 在application.yml中,添加Redis集群配置: ``` spring: redis: cluster: nodes: redis://localhost:7000,redis://localhost:7001,redis://localhost:7002 # Redis集群节点 ``` 三、配置Redis连接池 在application.yml中,添加Redis连接池配置: ``` spring: redis: timeout: 2000 # 连接超时时间 lettuce: pool: max-active: 8 # 最大连接数 max-idle: 8 # 最大空闲连接数 min-idle: 0 # 最小空闲连接数 ``` 四、配置RedisTemplate 在application.java中,添加RedisTemplate的Bean: ``` @Bean public RedisTemplate<String, Object> redisTemplate(LettuceConnectionFactory redisConnectionFactory) { RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>(); redisTemplate.setConnectionFactory(redisConnectionFactory); redisTemplate.setDefaultSerializer(new StringRedisSerializer()); redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer()); redisTemplate.setHashKeySerializer(new StringRedisSerializer()); redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer()); return redisTemplate; } ``` 五、测试Redis集群 在Controller中注入RedisTemplate,执行set和get操作进行测试。 ``` @Autowired private RedisTemplate<String, Object> redisTemplate; @RequestMapping("/set") public String set(String key, String value) { redisTemplate.opsForValue().set(key, value); return "set success"; } @RequestMapping("/get") public Object get(String key) { return redisTemplate.opsForValue().get(key); } ``` 以上是关于如何在Spring Boot项目中配置Redis集群的方法。如果你的系统数据量较大,且并发量较高,那么Redis集群将是你应该考虑的一种选择。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值