记一次由 jedis 引发的离谱选学问题

news2024/10/7 4:36:14

背景

我的应用中,使用 jedis 作为连接 redis 的客户端,一直在用的好好的,后来有一个新的组件,也需要使用 redis,但是组件是内部封装的,我只能提供一个 StringReidsTempalte,所以我基于应用本身构造的 factory,又重新构建了一个新的 template。

使用版本

springboot: 3.0.6
jedis: 4.3.2
redis 安装版本: 7.0.11
jdk: 17

现状

当时的现状就是这样的:

有一个统一的factory 构造器,构造一个 factory,并将这个 factory 交由 spring 管理。

应用内部统一使用的缓存客户端,由自定义构造一个 RedisTemplate,而新的组件,使用 factory 构造一个新的 StringRedisTemplate。

表象

我在本地启动的时候,没有任何问题,正常和 redis 交互。

部署到服务器启动的时候,会在实际和 redis 交互的底层逻辑处,报出异常。

报错位置1:

org.springframework.data.redis.connection.jedis.JedisStringCommands#set(byte[], byte[], org.springframework.data.redis.core.types.Expiration, org.springframework.data.redis.connection.RedisStringCommands.SetOption)

img在这个地址执行的时候,invoke 方法没问题,执行到 from 的时候,debug 执行,会报上面构建的 SetParams 这个类找不到。(只有 debug 会报,正常执行该堆栈打印不出)

通过解包,找到实际服务器的 jar 包中的 lib,发现对应的jar 包是有的,也存在这个类。

后面我就不管这个,果然就继续执行了,这个地方并无卡点。

执行到 getOrElse 的时候,就会报另外一个异常,也就是服务器会打印出来的异常,Unknown redis exception.

堆栈信息中,大概得处理逻辑就是从cgLib 中获取客户端的时候,会有一些地方有卡点,不过太过深入,没有继续追,肯定不是底层逻辑的 bug,只能是我的客户端构造的有问题。

于是我就开始仔细看我构造出来的客户端,和我正常的客户端比较。

然而这个也没有什么异常的情况。

我的自己构建的客户端连接池,正常使用,用了很久了,一直没问题,实际到底层的时候,都是在一个地方使用的,应该是没啥问题。

通过网上找关于 jedis 客户端的使用 demo,几乎和我的没差别,只是调优参数不一样。

jedis 报错:Unknown redis exception 的几种常见问题

  1. Redis 服务未启动或者未连接:在程序连接 Redis 时,如果 Redis 服务未启动或者程序无法连接到 Redis,就会出现这个异常。确保 Redis 服务已启动,且连接信息配置正确。
  2. Redis 服务故障:Redis 服务本身发生故障导致连接断开,也会引起这个异常。这时可以检查 Redis 服务是否正常,以及网络连接是否正常。
  3. Redis 客户端版本问题:Spring Data Redis 依赖于 lettuce 和 Jedis 客户端来访问 Redis。如果使用了不兼容的客户端版本,就会出现这个异常。确保 Spring Data Redis、lettuce 和 Jedis 的版本匹配。
  4. Redis 操作出错:使用 Redis 进行操作时,可能会遇到一些错误情况,如 key 不存在,操作类型不匹配等。这时检查 Redis 的操作是否合规,可以帮助解决这个异常。

针对这些可能产生该异常的情况,可以分别进行如下处理:

  1. 确认 Redis 服务已启动,并检查网络连接和连接信息是否正确。
  2. 检查 Redis 服务是否正常,以及网络连接是否正常。
  3. 选择适合的 Spring Data Redis、lettuce 和 Jedis 版本,确保版本匹配。
  4. 确认 Redis 的操作是否合规,以及检查 Redis key 是否存在。

解决问题

最终发现,根本无法下手,因为我本地是好的,java 版本都没问题。

最终尝试使用 lettuce。

问题解决,正常使用。

如果有各位大佬知道具体原因,欢迎交流!不胜感激!

拓展

lettuce 和 jedis比较

spring boot 本身默认使用的就是 lettuce,所以个人觉得直接使用 lettuce 会更好一些。

lettuce 是 jedis 的后起之秀,相较于 jedis 来说,lettuce 有如下优点

  • 线程安全(jedis 线程非安全)
  • 基于 Netty 框架的事件驱动通信,可以异步(jedis 为同步阻塞 IO,不支持异步)
  • 基于异步+线程安全,所以更适合分布式缓存。
    • ps:我的应用就是分布式的,考虑到有可能是线程安全导致的问题,所以尝试使用 lettuce,结果就解决问题了。(只是猜测可能是线程安全问题导致,并没有实际验证,虽然解决,可能只是误打误撞)

相较于 jedis,lettuce 的缺点也有

  • jedis 提供了更为全面的 reidis 操作特性的 api。
  • jedis 的 api 基本和 redis 的指令一一对应,使用简单,更容易理解。而 lettuce 的api 更抽象一些,学习成本会更高一些。

lettuce 使用

和 jedis 相比,lettuce 使用更简单,因为 lettuce 并不需要配置连接池,因为 lettuce 单链接的性能就很好,线程池数量太低,会导致性能降低,太高和单链接性能差异不大,但是资源消耗更多。

所以简单配置即可。

spring boot 3之后,也移除了直接配置连接池的入口。只需要简单配置 redis 的链接方式即可。

    @Bean("lettuceConnectionFactory")
    public RedisConnectionFactory lettuceConnectionFactory(CacheConfiguration configuration) {
        logger.info("开始构建 redis factory...{}", JedisConnectionFactory.class.getName());
//        GenericObjectPoolConfig<RedisProperties.Lettuce> poolConfig = getLettucePoolConfig();
//
//        LettuceClientConfiguration clientConfig = LettuceClientConfiguration.builder()
//                .build();
        RedisStandaloneConfiguration redisConfig = getRedisConfiguration(configuration);
//        LettuceConnectionFactory factory = new LettuceConnectionFactory(redisConfig, clientConfig);
        LettuceConnectionFactory factory = new LettuceConnectionFactory(redisConfig);
        factory.afterPropertiesSet();
        return factory;
    }

注意:lettuce 的 factory 创建完成之后,一定要调用afterPropertiesSet方法,否则在实际使用的时候就会报错。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1297019.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GPTs的创建与使用,自定义GPTs中的Actions示例用法 定义和执行特定任务的功能模块 通过API与外部系统或服务的交互

Name 等 Logo:自动生成 Name 介绍 Description 介绍 Instructions 要求或命令等 比如用中文回复&#xff0c;角色。 Knowledge 上传你的知识库&#xff0c;如果你有某一垂直行业的数据&#xff0c;基于数据来回答。比如我有某个芯片的指令集。 Capabilities 都要 Actions&…

ELasticsearch:什么是语义搜索?

语义搜索定义 语义搜索是一种解释单词和短语含义的搜索引擎技术。 语义搜索的结果将返回与查询含义匹配的内容&#xff0c;而不是与查询中的单词字面匹配的内容。 语义搜索是一组搜索引擎功能&#xff0c;其中包括根据搜索者的意图及其搜索上下文理解单词。 此类搜索旨在通过…

算法Day15 农场耕作

农场耕作 Description 你是一位农夫&#xff0c;拥有一块 m x n 的小农场。你打算在这块农场上耕种不同的农作物&#xff0c;以便在季节结束时获得最大的收成。 农场被分割成网格&#xff0c;每个格子代表不同的耕种区域&#xff0c;你可以选择每次向下或向右移动一格来耕作。…

解决 Element-ui中 表格(Table)使用 v-if 条件切换后,表格的列的筛选不显示了

解决方法 在每个需要使用 v-if 或 v-else 的 el-table-column 上增加 key 作为唯一标识&#xff0c;这样渲染的时候就不会因为复用原则导致列数据混乱了。关于key值&#xff0c;一般习惯使用字段名&#xff0c;也可随机生成一个值&#xff0c;只要具有唯一性就可以。

离散型制造企业MES系统行业应用

离散型制造企业具有产品种类多、生产周期长、生产过程复杂等特点&#xff0c;因此&#xff0c;采用先进的生产管理系统对于提高企业的生产效率和管理水平至关重要。其中&#xff0c;制造执行系统&#xff08;MES&#xff09;在离散型制造企业中得到了广泛应用&#xff0c; 一、…

RedisTemplate操作哈希数据

RedisTemplate操作哈希数据 概述常用方法添加哈希数据添加hashMap值判断hashkey 获取哈希数据获取属性值获取hashMap值。获取键值对。获取map键是否有值判断是否有map键。获取键。获取长度。集合方式获取值。匹配获取键值对 自增以double值大小自增。以long值大小自增。 修改删…

node.js和npm的安装与环境配置(2023最新版)

目录 安装node.js测试是否安装成功测试npm环境配置更改环境变量新建系统变量 安装node.js 1、进入官网下载&#xff1a;node.js官网 我选择的是windows64位的&#xff0c;你可以根据自己的实际情况选择对应的版本。 2、下载完成&#xff0c;安装。 打开安装程序 接受协议 选…

浅谈5G基站节能及数字化管理解决方案的设计与应用-安科瑞 蒋静

截至2023年10月&#xff0c;我国5G基站总数达321.5万个&#xff0c;占全国通信基站总数的28.1%。然而&#xff0c;随着5G基站数量的快速增长&#xff0c;基站的能耗问题也逐渐日益凸显&#xff0c;基站的用电给运营商带来了巨大的电费开支压力&#xff0c;降低5G基站的能耗成为…

js 复制粘贴板,当clipboardjs 不好使怎么办?

最近项目中做一个很常见的复制粘贴的功能耽误了比较长的时间特此记录&#xff0c;在往常这个功能直接用 clipboard 做就行了&#xff0c;但是这次却发现复制功能不好使了&#xff0c;虽然走了复制成功的回调&#xff0c;但是粘贴板并没有复制的内容。代码如下 <div v-for&q…

使用LangSmith来快速学习LangChain

好风凭借力&#xff0c;送我上青云&#xff01; 什么是LangSmith LangSmith is a platform for building production-grade LLM applications. It lets you debug, test, evaluate, and monitor chains and intelligent agents built on any LLM framework and seamlessly int…

oracle12c的job没有自动执行,手动运行提示任务1%正在运行问题

有个oracle12c上的job&#xff0c;提交到dbms_job&#xff0c;不知道什么时候开始&#xff0c;停下来了&#xff0c;没有自动运行。 手动关闭这个job&#xff0c;重新打开&#xff0c;不行&#xff1b;删除JOB&#xff0c;重新创建&#xff0c;也不行。 参考拙作&#xff1a; …

Leetcode 39 组合总和

题意理解&#xff1a; 一个 无重复元素 的整数数组 candidates 和一个目标整数 target 从candidates 取数字&#xff0c;使其和 target &#xff0c;有多少种组合&#xff08;candidates 中的 同一个 数字可以 无限制重复被选取&#xff09; 这道题和之前一道组合的区别&am…

【USB、串口、COM口、TTL、RS-232、RS-485区别详解】

USB&#xff0c;串口&#xff0c;COM口&#xff0c;TTL&#xff0c;RS-232&#xff0c;RS-485区别详解 1. USB&#xff0c;串口&#xff0c;COM口&#xff0c;TTL&#xff0c;RS-232&#xff0c;RS-485区别详解2 USB转TTL2 RS-232转TTL3 USB4 UART5 STM32串口异步通讯需要定义的…

2024年AI视频识别技术的6大发展趋势预测

随着人工智能技术的快速发展&#xff0c;AI视频识别技术也将会得到进一步的发展和应用。2023年已经进入尾声&#xff0c;2024年即将来临&#xff0c;那么AI视频识别技术又将迎来怎样的发展趋势&#xff1f;本文将对2023年的AI视频技术做一个简单的盘点并对2024年的发展趋势进行…

c/c++中一些不常用但有用的知识

1.变长数组 bool fun(int cnt) {unsigned char data[cnt];return true; } 在 C 语言中&#xff0c;变长数组&#xff08;Variable Length Arrays&#xff0c;VLA&#xff09;是 C99 标准引入的特性&#xff0c;允许使用变量来定义数组的长度。因此&#xff0c;在 C 版本的代码…

Oauth2.0 认证

目录 前言 1.介绍 2.Oauth2.0过程详解 3.Oauth 整合到 Spring Boot 实践 4.方法及配置详解&#xff1a; 总结 前言 Oauth2.0 是非常流行的网络授权表准&#xff0c;已经广泛应用在全球范围内&#xff0c;比较大的公司&#xff0c;如腾讯等都有大量的应用场景。 1.介绍 …

Qt工程文件分离、Qtimer定时器、Qt Creator 常用快捷键

Qt 工程文件分离 不含 UI 的文件分离 以堆栈窗体的代码为例。 firstpagewidget.h #ifndef FIRSTPAGEWIDGET_H #define FIRSTPAGEWIDGET_H#include <QtWidgets> // 记得修改class firstPageWidget : public QWidget {Q_OBJECT public:explicit firstPageWidget(QW…

Python表单处理

目录 通过Flask处理表单 通过Flask-WTF处理表单 通过Flask-WTF验证表单 通过Flask处理表单 表单是在网页中搜集用户信息的各种表单控件的集合区域&#xff0c;表单控件包括文本框、单选框、复选框、提交按钮等&#xff0c;用于实现客户端和服务器端之间的数据交互。 利用F…

uniapp各种小程序分享 share - 主要流程 - 微信、抖音、快手、qq

参考 小程序环境 分享 | uni-app官网uni-app,uniCloud,serverless,分享,uni.share(OBJECT),分享到微信聊天界面示例代码,分享到微信朋友圈示例代码,uni.share 在App端各社交平台分享配置说明,uni.shareWithSystem(OBJECT),plus.share.sendWithhttps://uniapp.dcloud.net.cn/a…

监控pod 容器外网请求网络带宽,过滤掉内网、基于k8spacket开发

首先安装k8spacket 安装k8spacket遇到问题&#xff0c;下载插件一直能不能下载成功&#xff0c;pod不能启动。所有手动下载处理。 helm repo add k8spacket https://k8spacket.github.io/k8spacket-helm-chart helm pull k8spacket/k8spacket打开values.yaml 文件 手动下载插…