当前位置: 首页 > news >正文

16 redis高可用读写分离方案

在前面说的JedisSentinelPool只能实现主从的切换,而无法实现读写的分离

1.哨兵的客户端实现主从切换方案
<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><!-- https://mvnrepository.com/artifact/redis.clients/jedis --><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>3.6.3</version></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build>
# Redis哨兵服务器地址
redis.sentinel=aliyun:26885,aliyun:26886,aliyun:26887
redis.master=mymaster
# Redis服务器连接密码(默认为空)
redis.password=null
redis.timeout=30000
# 连接池最大连接数(使用负值表示没有限制)
redis.maxTotal=30
# 连接池中的最大空闲连接
redis.maxIdle=10
redis.numTestsPerEvictionRun=1024
redis.timeBetweenEvictionRunsMillis=30000
redis.minEvictableIdleTimeMillis=1800000
redis.softMinEvictableIdleTimeMillis=10000
# 连接池最大阻塞等待时间(使用负值表示没有限制)
redis.maxWaitMillis=1500
redis.testOnBorrow=true
redis.testWhileIdle=true
redis.blockWhenExhausted=false
redis.JmxEnabled=true
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.PropertySource;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
import redis.clients.jedis.JedisSentinelPool;import java.util.HashSet;
import java.util.Set;@Configuration
@PropertySource("classpath:application.properties")
public class RedisSentinelConfig {@Value("${redis.sentinel}")private String hosts;@Value("${redis.master}")private String master;@Value("${redis.timeout}")private int timeout;@Value("${redis.maxIdle}")private int maxIdle;@Value("${redis.maxWaitMillis}")private int maxWaitMillis;@Value("${redis.blockWhenExhausted}")private Boolean blockWhenExhausted;@Value("${redis.JmxEnabled}")private Boolean JmxEnabled;@Beanpublic JedisPoolConfig  jedisPoolConfigFactory() {JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();jedisPoolConfig.setMaxIdle(maxIdle);jedisPoolConfig.setMaxWaitMillis(maxWaitMillis);// 连接耗尽时是否阻塞, false报异常,true阻塞直到超时, 默认truejedisPoolConfig.setBlockWhenExhausted(blockWhenExhausted);// 是否启用pool的jmx管理功能, 默认truejedisPoolConfig.setJmxEnabled(JmxEnabled);jedisPoolConfig.setTestOnBorrow(true);jedisPoolConfig.setTestOnReturn(true);return jedisPoolConfig;}@Beanpublic JedisSentinelPool JedisSentinelPoolFactory(JedisPoolConfig jedisPoolConfig){Set<String> nodeSet = new HashSet<>();//获取到节点信息String nodeString = hosts;//判断字符串是否为空if(nodeString == null || "".equals(nodeString)){throw new RuntimeException("RedisSentinelConfiguration initialize error nodeString is null");}String[] nodeArray = nodeString.split(",");//判断是否为空if(nodeArray == null || nodeArray.length == 0){throw new RuntimeException("RedisSentinelConfiguration initialize error nodeArray is null");}//循环注入至Set中for(String node : nodeArray){System.out.println("Read node : "+node);nodeSet.add(node);}//创建连接池对象JedisSentinelPool jedisSentinelPool = new JedisSentinelPool(master,nodeSet,jedisPoolConfig ,timeout);return jedisSentinelPool;}}
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisSentinelPool;/*** 操作字符串类型*/
@Component
public class RedisString {public final static String RS_STR_NS = "rs:";@Autowiredprivate JedisSentinelPool jedisSentinelPool;/*** 向Redis中存值,永久有效*/public String set(String key, String value) {Jedis jedis = null;try {jedis = jedisSentinelPool.getResource();return jedis.set(RS_STR_NS +key, value);} catch (Exception e) {throw new RuntimeException("向Redis中存值失败!");} finally {jedis.close();}}/*** 批量向Redis中存值,永久有效*/public String msetRaw(String... keysvalues) {Jedis jedis = null;try {jedis = jedisSentinelPool.getResource();return jedis.mset(keysvalues);} catch (Exception e) {throw new RuntimeException("批量向Redis中存值失败!");} finally {jedis.close();}}/*** 根据传入Key获取指定Value*/public String get(String key) {Jedis jedis = null;try {jedis = jedisSentinelPool.getResource();return jedis.get(RS_STR_NS +key);} catch (Exception e) {throw new RuntimeException("获取Redis值失败!");} finally {jedis.close();}}}
2、读写分离的实现

需要自己去封装代码实现。
待补充

相关文章:

16 redis高可用读写分离方案

在前面说的JedisSentinelPool只能实现主从的切换&#xff0c;而无法实现读写的分离。 1.哨兵的客户端实现主从切换方案 <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</arti…...

Nginx模块开发之http handler实现流量统计(2)

文章目录 一、概述二、Nginx handler模块开发2.1、代码实现2.2、编写config文件2.3、编译模块到Nginx源码中2.4、修改conf文件2.5、执行效果 总结 一、概述 上一篇【Nginx模块开发之http handler实现流量统计&#xff08;1&#xff09;】使用数组在单进程实现了IP的流量统计&a…...

案例012:Java+SSM+uniapp基于微信小程序的科创微应用平台设计与实现

文末获取源码 开发语言&#xff1a;Java 框架&#xff1a;SSM JDK版本&#xff1a;JDK1.8 数据库&#xff1a;mysql 5.7 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.5.4 小程序框架&#xff1a;uniapp 小程序开发软件&#xff1a;HBuilder X 小程序…...

vue3+elementPlus登录向后端服务器发起数据请求Ajax

后端的url登录接口 先修改main.js文件 // 导入Ajax 前后端数据传输 import axios from "axios"; const app createApp(App) //vue3.0使用app.config.globalProperties.$http app.config.globalProperties.$http axios app.mount(#app); login.vue 页面显示部分…...

存储区域

将应用程序加载到内存空间执行时&#xff0c;操作系统负责代码段、数据段和BSS段的加载&#xff0c;并在内存中为这些段分配空间。 栈段亦由操作系统分配和管理&#xff0c;而不需要程序员显示地管理&#xff1b;堆段由程序员自己管理&#xff0c;即显示地申请和释放空间。 进…...

C#串口通信从入门到精通(27)——高速通信下解决数据处理慢的问题(20ms以内)

前言 我们在开发串口通信程序时,有时候会遇到比如单片机或者传感器发送的数据速度特别快,比如10ms、20ms发送一次,并且每次发送的数据量还比较大,如果按照常规的写法,我们会发现接收的数据还没处理完,新的数据又发送过来了,这就会导致处理数据滞后,软件始终处理的不是…...

Redis-Redis高可用集群之水平扩展

Redis3.0以后的版本虽然有了集群功能&#xff0c;提供了比之前版本的哨兵模式更高的性能与可用性&#xff0c;但是集群的水平扩展却比较麻烦&#xff0c;今天就来带大家看看redis高可用集群如何做水平扩展&#xff0c;原始集群(见下图)由6个节点组成&#xff0c;6个节点分布在三…...

2023全球数字贸易创新大赛-人工智能元宇宙-4-10

目录 竞赛感悟: 创业的话 好的项目 数字工厂,智慧制造:集群控制的安全问题...

go defer用法_类似与python_java_finially

defer 执行 时间 defer 一般 定义在 函数 开头, 但是 他会 最后 被执行 A defer statement defers the execution of a function until the surrounding function returns. 如果说 为什么 不在 末尾 定义 defer 呢, 因为 当 错误 发生时, 程序 执行 不到 末尾 就会 崩溃. d…...

Log4j2.xml不生效:WARN StatusLogger Multiple logging implementations found:

背景 将 -Dlog4j.debug 添加到IDEA的类的启动配置中 运行上图代码&#xff0c;这里log4j2.xml控制的日志级别是info&#xff0c;很明显是没生效。 DEBUG StatusLogger org.slf4j.helpers.Log4jLoggerFactory is not on classpath. Good! DEBUG StatusLogger Using Shutdow…...

【LeetCode】挑战100天 Day14(热题+面试经典150题)

【LeetCode】挑战100天 Day14&#xff08;热题面试经典150题&#xff09; 一、LeetCode介绍二、LeetCode 热题 HOT 100-162.1 题目2.2 题解 三、面试经典 150 题-163.1 题目3.2 题解 一、LeetCode介绍 LeetCode是一个在线编程网站&#xff0c;提供各种算法和数据结构的题目&…...

VMware安装windows操作系统

一、下载镜像包 地址&#xff1a;镜像包地址。 找到需要的版本下载镜像包。 二、安装 打开VMware新建虚拟机&#xff0c;选择用镜像文件。将下载的镜像包加载进去即可。...

历时半年,我发布了一款习惯打卡小程序

半年多前&#xff0c;我一直困扰于如何记录习惯打卡情况&#xff0c;在参考了市面上绝大多数的习惯培养程序后&#xff0c;终于创建并发布了这款习惯打卡小程序。 “我的小日常打卡”小程序主要提供习惯打卡和专注训练功能。致力于培养用户养成一个个好的习惯&#xff0c;改掉…...

被DDOS了怎么办 要如何应对

DDoS攻击的特点和类型 1. 特点 DDoS攻击的特点是通过大量合法的请求或者无效的请求&#xff0c;消耗目标服务器的网络带宽和系统资源&#xff0c;使其无法正常运行。攻击者通常使用多个主机发起攻击&#xff0c;以达到更高的攻击效果。 2. 常见类型 &#xff08;1&#xff09;S…...

时间序列预测实战(十七)PyTorch实现LSTM-GRU模型长期预测并可视化结果(附代码+数据集+详细讲解)

一、本文介绍 本文给大家带来的实战内容是利用PyTorch实现LSTM-GRU模型&#xff0c;LSTM和GRU都分别是RNN中最常用Cell之一&#xff0c;也都是时间序列预测中最常见的结构单元之一&#xff0c;本文的内容将会从实战的角度带你分析LSTM和GRU的机制和效果&#xff0c;同时如果你…...

【免费使用】基于PaddleSeg开源项目开发的人像抠图Web API接口

基于PaddleSeg开源项目开发的人像抠图API接口&#xff0c;服务器不存储照片大家可放心使用。 1、请求接口 请求地址&#xff1a;http://apiseg.hysys.cn/predict_img 请求方式&#xff1a;POST 请求参数&#xff1a;{"image":"/9j/4AAQ..."} 参数是jso…...

Centos7 Python环境和yum修复

1、删除现有残余包 [rootlocalhost ]# rpm -qa|grep python|xargs rpm -ev --allmatches --nodeps[rootlocalhost ]# rpm -qa|grep yum|xargs rpm -ev --allmatches --nodeps[rootlocalhost ]# whereis python |xargs rm -frv[rootlocalhost ]# whereis python ##验证清除&…...

Ubuntu下使用protoBuf

一、protobuf简介&#xff1a; 1.1 protobuf的定义&#xff1a; protobuf是用来干嘛的&#xff1f; protobuf是一种用于 对结构数据进行序列化的工具&#xff0c;从而实现 数据存储和交换。 &#xff08;主要用于网络通信中 收发两端进行消息交互。所谓的“结构数据”是指类…...

AT89S52单片机

目录 一.AT89S52单片机的硬件组成 1.CPU(微处理器) (1)运算器 (2)控制器 2.数据存储器 (RAM) (1)片内数据存储器 (2)片外数据存储器 3.程序存储器(Flash ROM) 4.定时器/计数器 5.中断系统 6.串行口 7.P0口、P1口、P2口和P3口 8.特殊功能寄存器 (SFR) 常用的特殊功…...

数字孪生智慧校园 Web 3D 可视化监测

当今&#xff0c;智慧校园发展阶段亟需推动信息可视化建设与发展&#xff0c;将大数据、云计算、可视化等高新技术相融合&#xff0c;为校园师生创造科学智能的学习环境&#xff0c;并实现教学资源最大化和信息服务智能化。帮助学校更好地应用校园可视化技术&#xff0c;提升校…...

DeepSeek V4 预览版实测:Agent、世界知识、推理能力,跟 V3 和 GPT-5.5/Claude 4.6 比到底什么水平?

上周 DeepSeek 放出了 V4 预览版的 API&#xff0c;我第一时间拿到了访问权限。说实话&#xff0c;官方博客里那些 benchmark 数字看着确实唬人——Agent 能力大幅提升、世界知识超越 GPT-5、推理逼近 Claude Opus 4.6。但作为一个被各家"自评跑分"坑过无数次的人&am…...

WarcraftHelper:魔兽争霸III终极增强插件完全指南

WarcraftHelper&#xff1a;魔兽争霸III终极增强插件完全指南 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸III的陈旧限制而烦恼吗&a…...

如何搭建一个药品市场价格监控智能体来实现100%价格一致性? —— 2026全渠道价格均衡化架构实战指南

在2026年的医药流通领域&#xff0c;随着《关于健全药品价格形成机制的若干意见》的全面深化落实&#xff0c;药品价格监管已从“事后查处”转向“实时监测与动态预警”。 所谓的“100%价格一致性”&#xff0c;在当前政策语境下&#xff0c;并非指全国所有药店的药品价格必须分…...

从无人机到扫地机:聊聊机器人‘眼睛’(图像传感器)为什么怕抖?全局快门与卷帘快门选型指南

机器人视觉的防抖革命&#xff1a;全局快门与卷帘快门的工程博弈战 当扫地机器人撞上桌腿、无人机在风中丢失定位、AGV小车突然误判障碍物时&#xff0c;问题往往出在那双"看不见的眼睛"上。图像传感器作为机器人的视觉神经末梢&#xff0c;其快门机制的选择直接影响…...

用STK分析北斗三号MEO星座:手把手教你计算全球任意区域的PDOP和可见卫星数

北斗三号MEO星座性能评估实战&#xff1a;STK软件操作全流程解析 在卫星导航系统设计与优化过程中&#xff0c;准确评估定位精度和卫星可见性是核心环节。作为行业标准工具&#xff0c;STK&#xff08;Systems Tool Kit&#xff09;软件提供了从星座建模到性能分析的完整解决方…...

避坑指南:解决ptp4l报错‘failed to create a clock’的三种方法(附网卡支持检测)

深度解析ptp4l报错failed to create a clock的完整解决方案 当你在Linux系统上部署ptp4l进行高精度时间同步时&#xff0c;遇到"failed to create a clock"或"interface does not support requested timestamping mode"这类错误信息&#xff0c;往往意味着…...

别再只用groupby().mean()了!Pandas分组后agg、apply、transform的保姆级选择指南

Pandas分组操作进阶指南&#xff1a;如何精准选择agg/apply/transform方法 刚接触Pandas的groupby时&#xff0c;我们往往满足于简单的.mean()或.sum()操作。但随着数据分析需求复杂化&#xff0c;你会发现groupby后面跟着的agg、apply和transform这三个方法才是真正的"瑞…...

LFM2-2.6B-GGUF多场景应用:法律合同要点提取、医疗报告术语解释

LFM2-2.6B-GGUF多场景应用&#xff1a;法律合同要点提取、医疗报告术语解释 1. 项目介绍 LFM2-2.6B-GGUF是由Liquid AI公司开发的一款轻量级大语言模型&#xff0c;经过GGUF量化处理后&#xff0c;体积大幅缩小但保留了强大的文本处理能力。这个模型特别适合在资源有限的设备…...

3PEAK思瑞浦 TPR6040F33-S3TR SOT23G-3 电压基准芯片

特性 固定输出电压: -2.048V、2.5V、3V、3.3V、4.096V和5V 高初始精度和低温系数 -A级:最大0.1%&#xff0c;25ppm/C -B级:最大0.2%&#xff0c;50ppm/C 工作温度范围:-40C至125C 滴流能力:150A至15mA 适用于任何电容负载&#xff0c;稳定可靠 封装:SOT23G-3...

EasyExcel分批写入实战:规避.withTemplate陷阱,高效防OOM方案解析

1. 为什么.withTemplate会成为内存杀手&#xff1f; 最近在优化一个数据导出功能时&#xff0c;我遇到了一个典型的OOM&#xff08;内存溢出&#xff09;问题。场景是这样的&#xff1a;需要将百万级数据分批查询后写入Excel&#xff0c;最初采用了.withTemplate(file)的方式合…...