栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

SpringBoot 配置redis集群

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringBoot 配置redis集群

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 nodes = new HashSet();
        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;
    }
}

 (2).使用

//1.指定存储类型
@Autowired
private RedisTemplate 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 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;
 }

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/841044.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号