使用 Jedis 连接 Redis Cluster
2021/7/17 19:09:55
本文主要是介绍使用 Jedis 连接 Redis Cluster,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
文章目录
- 1. 引入依赖
- 2. 参数配置
- 3. 代码实现
1. 引入依赖
<dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.9.0</version> </dependency>
2. 参数配置
# Redis集群服务器地址 redis.host1=192.168.000.11 redis.host2=192.168.000.12 redis.host3=192.168.000.13 # Redis服务器连接端口 redis.master.port=6379 redis.slave.port=6380 # Redis服务器连接密码(默认为空) redis.password=xxxx # 连接超时时间 redis.connection-timeout=2000 # 读取数据超时时间 redis.so-timeout=2000 # 连接超时或读取超时进行重试的次数 redis.max-attempts=3 # 开启对象验证,保证可用 redis.testOnBorrow=true
3. 代码实现
import lombok.extern.slf4j.Slf4j; import redis.clients.jedis.HostAndPort; import redis.clients.jedis.JedisCluster; import redis.clients.jedis.JedisPoolConfig; import java.io.IOException; import java.util.HashSet; import java.util.Properties; import java.util.Set; /** * Redis Cluster 配置 * * @author wangbo * @date 2021/6/15 */ @Slf4j public class JedisClusterManager { private JedisClusterManager() { } private static final JedisCluster JEDIS_CLUSTER; static { Properties props = new Properties(); try { props.load(JedisClusterManager.class.getResourceAsStream(PropertiesConstants.PROPERTIES_FILE_REDIS)); } catch (IOException e) { log.error("load redis config properties exception", e); } String redisHost1 = props.getProperty("redis.host1"); String redisHost2 = props.getProperty("redis.host2"); String redisHost3 = props.getProperty("redis.host3"); int masterPort = Integer.parseInt(props.getProperty("redis.master.port")); int slavePort = Integer.parseInt(props.getProperty("redis.slave.port")); Set<HostAndPort> nodes = new HashSet<>(); nodes.add(new HostAndPort(redisHost1, masterPort)); nodes.add(new HostAndPort(redisHost2, masterPort)); nodes.add(new HostAndPort(redisHost3, masterPort)); nodes.add(new HostAndPort(redisHost1, slavePort)); nodes.add(new HostAndPort(redisHost2, slavePort)); nodes.add(new HostAndPort(redisHost3, slavePort)); String password = props.getProperty("redis.password"); int connectionTimeout = Integer.parseInt(props.getProperty("redis.connection-timeout")); int soTimeout = Integer.parseInt(props.getProperty("redis.so-timeout")); int maxAttempts = Integer.parseInt(props.getProperty("redis.max-attempts")); boolean testOnBorrow = Boolean.parseBoolean(props.getProperty("redis.testOnBorrow")); JedisPoolConfig jedisPoolConfig = new JedisPoolConfig(); jedisPoolConfig.setTestOnBorrow(testOnBorrow); JEDIS_CLUSTER = new JedisCluster(nodes, connectionTimeout, soTimeout, maxAttempts, password, jedisPoolConfig); } /** * 获取JedisCluster对象 */ public static JedisCluster getJedis() { return JEDIS_CLUSTER; } }
然后每次使用的时候直接在程序中使用如下代码获取 JedisCluster 对象即可使用 Jedis 提供的各种操作 Redis 的方法:
JedisCluster jedisCluster = JedisClusterManager.getJedis();
这篇关于使用 Jedis 连接 Redis Cluster的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-02阿里云Redis项目实战入门教程
- 2025-01-02阿里云Redis资料入门详解
- 2024-12-30阿里云Redis教程:新手入门指南
- 2024-12-27阿里云Redis学习入门指南
- 2024-12-27阿里云Redis入门详解:轻松搭建与管理
- 2024-12-27阿里云Redis学习:新手入门指南
- 2024-12-24Redis资料:新手入门快速指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-24Redis资料:新手入门教程与实践指南
- 2024-12-07Redis高并发入门详解