Java通过JedisSentinelPool连接Redis,master切换无影响。

本文介绍了一种使用Java的JedisSentinelPool连接Redis并实现master切换时数据插入不受影响的方法。通过具体代码展示了如何配置连接池、设置超时时间及密码,并通过循环演示了实际的数据写入流程。

网上搜了很久,发现很多 Redis高可用的方案,发现这种是最符合我的情况的。master.disconnect();用于清理链接。

希望对你有所帮助。

Java通过JedisSentinelPool连接Redis,实现插入时master的切换无影响。

import java.util.HashSet;
import java.util.Set;
import redis.clients.jedis.HostAndPort;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPoolConfig;
import redis.clients.jedis.JedisSentinelPool;
public class JRedisSentinelTest {
public static void main(String[] args) throws InterruptedException {
    //服务IP
    String ip = "xx.xx.xx.xx";
    int TimeOut = 10000;
    JedisPoolConfig config = new JedisPoolConfig();
    config.setMaxTotal(200);
    config.setMaxIdle(50);
  //在获取连接的时候检查有效性, 
  //config.setTestOnBorrow(true);
  //在空闲时检查有效性, 默认false
  //config.setTestWhileIdle(true);
    config.setMaxWaitMillis(1000);
    String masterName = "mymaster";
    String password = "123456";
    
    Set sentinels = new HashSet();
    //Sentine端口
    sentinels.add(new HostAndPort(ip, 26371).toString());
    sentinels.add(new HostAndPort(ip, 26372).toString());
    sentinels.add(new HostAndPort(ip, 26373).toString());
    JedisSentinelPool sentinelPool = new JedisSentinelPool(masterName, sentinels, config, TimeOut,password);
    System.out.println("Current master: " + sentinelPool.getCurrentHostMaster().toString());
    for(int i=0;i<1000;i++) {
        Jedis master = sentinelPool.getResource();
        master.set(""+i,""+i);
        System.out.println("第"+i+"次沉睡");
        master.close();
        master.disconnect();
        Thread.sleep(5000);
    }
    sentinelPool.destroy();
}

}

在 Spring Boot 程序中实现 Redis 主从数据库连接切换,通常是为了提高系统的读取性能和高可用性。通过配置主从复制模式下的 Redis 实例集群,当主节点发生故障时可以从节点能够接替服务,同时还可以将一些查询请求分发给从节点减轻主节点的压力。 以下是具体的步骤及注意事项: ### 1. 引入依赖 首先需要确保项目中有合适的 Redis 相关依赖。比如 Jedis 或者 Lettuce 库。这里以常用的 `spring-boot-starter-data-redis` 为例: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency> ``` ### 2. 配置 Redis 主从地址 接下来是在 `application.properties` 文件内添加 Master 和 Slave 的连接信息。可以分别列出主机名/IP 及端口号等详细内容。下面是一个简单的例子说明如何设置两个以上的 Redis 实例作为主从结构的一部分: #### application.yml 示例: ```yaml spring: redis: # 主库配置 master: host: localhost # 替换为实际的IP地址或域名 port: 6379 # 默认Redis端口 # 从库配置(如果有多个可以用逗号隔开) slave: hosts: - ip_of_slave_1:port # 第一个从机的信息 - ip_of_slave_2:port # 如果有第二个从机... ``` 不过需要注意的是,直接这样简单地定义并不是最佳实践,因为Spring并没有内置支持这种形式的YAML解析成复杂的数据源对象。因此我们建议采用另一种更灵活的方式——自定义 Bean 创建逻辑。 ### 3. 自定义 RedisConfig 类 编写自己的 RedisConfiguration 类来自动生成对应的 RedisTemplate 对象用于业务代码中访问数据存储系统。在这个过程中特别要注意区分master/slave角色以及合理分配读写流量。 #### RedisConfig.java 示例: ```java @Configuration public class RedisConfig { @Value("${spring.redis.master.host}") private String masterHost; @Value("${spring.redis.master.port}") private int masterPort; // 动态获取所有slave服务器列表,并将其构造成List格式 @Autowired private Environment env; private List<String> getSlaves() { return Arrays.stream(env.getProperty("spring.redis.slave.hosts", String[].class)) .collect(Collectors.toList()); } /** * 构建Master-Slave架构的JedisPoolConfig. */ @Bean(name = "jedisSentinelPool") public JedisPool createJedisCluster() throws Exception { Set<String> sentinels = new HashSet<>(); for (String slaves : this.getSlaves()) { String[] split = slaves.split(":"); if(split.length == 2){ sentinels.add(slaves); } else{ throw new IllegalArgumentException("Invalid sentinel address format."); } } GenericObjectPoolConfig poolConfig = new GenericObjectPoolConfig(); // 设置池的基本参数... return new JedisSentinelPool( Collections.singletonList(master), sentinels, poolConfig, null, // 密码为空则设null "mymaster"); // Sentinel监控组名称 } } ``` 以上示例仅供参考,具体实现可能会依据选用的不同客户端而有所差异(如Lettuce)。另外还需结合实际情况调整相关参数设定。 ### 4. 使用 ReadWriteSplittingDataSource 进行动态路由 为了让应用程序自动识别出当前正在工作的机器是哪一个并且智能地把“写”操作发送至 master,“读”操作分散到各个 salve 上面去完成,你可以引入第三方组件来做这件事儿;当然也可以基于上面提到的基础之上进一步深入开发一套属于你自己项目的解决方案。 目前较为流行的方案之一就是借助 [ReadWriteSplitting](https://github.com/alibaba/spring-cloud-alibaba/blob/master/docs/README-zh.md#%E8%A7%81%E8%A7%A3) 技术来帮助达成目的。它能让你轻松指定规则让某些事务只走 master 路径,其余时候都去找 slave 来做优化处理。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值