windows下Springboot集成Redis集群

1pom配置引入

        <!-- 支持Redis集群 -->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-data-redis</artifactId>
		</dependency>
		<!-- 实现Jedis连接,一个连接池的作用 -->
		 <dependency>
		   <groupId>redis.clients</groupId>
		   <artifactId>jedis</artifactId>
		</dependency>

2application.properties配置

#Redis 单机配置
# REDIS (RedisProperties)
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
#spring.redis.host=localhost
# Redis服务器连接端口
#spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=
# 连接池最大连接数(使用负值表示没有限制)
spring.redis.jedis.pool.max-active=8
# 连接池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.jedis.pool.max-wait=-1
# 连接池中的最大空闲连接
spring.redis.jedis.pool.max-idle=8
# 连接池中的最小空闲连接
spring.redis.jedis.pool.min-idle=0
# 连接超时时间(毫秒)
spring.redis.timeout=0
spring.redis.commandTimeout=5000

# redis.cluster集群节点
spring.redis.cluster.nodes=192.168.43.187:6379,192.168.43.187:6380,192.168.43.187:6381

3文件配置java类

  1. 加载集群节点,创建集群对象
@Configuration
public class RedisConfig {
//集群方式   配置集群
	@Value("${spring.redis.cluster.nodes}")
    private String clusterNodes;
    @Value("${spring.redis.timeout}")
    private int timeout;
    @Value("${spring.redis.jedis.pool.max-idle}")
    private int maxIdle;
    @Value("${spring.redis.jedis.pool.max-wait}")
    private long maxWaitMillis;
    @Value("${spring.redis.commandTimeout}")
    private int commandTimeout;

 @Bean
    public JedisCluster getJedisCluster() {
        String[] cNodes = clusterNodes.split(",");
        Set<HostAndPort> nodes =new HashSet<>();
        //分割出集群节点
        for(String node : cNodes) {
        	String[] hp = node.split(":");
            nodes.add(new HostAndPort(hp[0].trim(),Integer.parseInt(hp[1].trim())));
        }
        JedisPoolConfig jedisPoolConfig =new JedisPoolConfig();
        jedisPoolConfig.setMaxIdle(maxIdle);
        jedisPoolConfig.setMaxWaitMillis(maxWaitMillis);
        //创建集群对象
//      JedisCluster jedisCluster = new JedisCluster(nodes,commandTimeout);
        return new JedisCluster(nodes,commandTimeout,jedisPoolConfig);
    }


}
  1. 调用集群,实现RedisClientTemplate。其实就是调用RedisConfig 的get获取集群对象,来操作Redis,基本的操作
@Service
public class RedisClientTemplate {
	
	 private static final Logger log=LoggerFactory.getLogger(RedisClientTemplate.class);

	private static final SortingParams List = null;

	@Autowired
	private RedisConfig jedisClusterConfig;

	public boolean setToRedis(String key, Object value) {
		try {
			String str = jedisClusterConfig.getJedisCluster().set(key,String.valueOf(value));
			System.out.println("str=="+str);
			if ("OK".equals(str))
				return true;
		} catch (Exception ex) {
			 log.error("setToRedis:{Key:"+key+",value"+value+"}",ex);
		}
		return false;
	}
	
	public boolean setMusicListToRedis(String key, List value) {
		List list = value ;
		try {
			Long str = jedisClusterConfig.getJedisCluster().lpush(key,"list","list","list");
			System.out.println("str=="+str);
			if ("OK".equals(str))
				return true;
		} catch (Exception ex) {
			 log.error("setToRedis:{Key:"+key+",value"+value+"}",ex);
		}
		return false;
	}

	public Object getRedis(String key) {
		String str = null;
		try {
			str = jedisClusterConfig.getJedisCluster().get(key);
		} catch (Exception ex) {
			
		}
		return str;
	}
}

4开启3个Redis服务配置了端口就可以正常操作了。
Redis集群的可能遇到的一些问题也在之前提到过

https://blog.csdn.net/qq_35736252/article/details/88814233
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot项目中,有三种方式可以集成Redis集群,包括使用Jedis、Lettuce和RedisTemplate。 对于Jedis的整合步骤,你需要先导入相应的依赖,包括spring-boot-starter-data-redis和lettuce-core。然后,你可以通过配置类来修改Swagger配置,以便适应你的项目需求。具体的代码实现可以参考上面给出的示例。 对于Lettuce的整合步骤,你同样需要导入相应的依赖,包括spring-boot-starter-data-redis和lettuce-core。然后,你可以在配置类中根据需要修改Swagger配置。具体的代码实现可以参考上面给出的示例。 对于RedisTemplate的整合步骤,你同样需要导入相应的依赖,包括spring-boot-starter-data-redis和lettuce-core。然后,你可以在配置类中根据需要修改Swagger配置。具体的代码实现可以参考上面给出的示例。 总结来说,不论是使用Jedis、Lettuce还是RedisTemplate,你都需要导入相应的依赖并进行相应的配置,以便在Spring Boot项目中实现Redis集群的整合。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [springboot整合redis集群](https://blog.csdn.net/m0_68574821/article/details/129899360)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot整合Redis](https://blog.csdn.net/l_zl2021/article/details/129368515)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值