主流Java Redis客户端深度对比:Jedis、Lettuce与Redisson性能特性全解析

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
持续学习,不断总结,共同进步,为了踏实,做好当下事儿~
非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

在这里插入图片描述

💖The Start💖点点关注,收藏不迷路💖

📒文章目录

    • 1. 核心架构与设计理念
      • 1.1 Jedis:同步阻塞式客户端
      • 1.2 Lettuce:异步非阻塞式客户端
      • 1.3 Redisson:分布式服务封装
    • 2. API设计与使用体验
      • 2.1 基础操作对比
      • 2.2 事务与Pipeline支持
      • 2.3 异常处理差异
    • 3. 性能与资源消耗
      • 3.1 基准测试数据(Redis 6.0,8核16G环境)
      • 3.2 线程模型对比图
    • 4. 高级功能与生态整合
      • 4.1 分布式锁实现对比
      • 4.2 Spring Boot集成配置
    • 5. 选型建议与总结
      • 5.1 决策流程图
      • 5.2 版本兼容性矩阵


1. 核心架构与设计理念

1.1 Jedis:同步阻塞式客户端

Jedis采用经典的BIO线程模型,每个物理连接独占一个线程。当执行jedis.get()等操作时,调用线程会阻塞直到收到Redis响应。典型连接管理通过JedisPool实现:

// 创建连接池配置
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(20);  // 最大连接数
JedisPool pool = new JedisPool(config, "localhost");try (Jedis jedis = pool.getResource()) {String value = jedis.get("key");  // 同步阻塞调用
}

优势:实现简单,与传统JDBC用法相似
劣势:高并发时线程资源消耗大(万级QPS需数百线程)

1.2 Lettuce:异步非阻塞式客户端

基于Netty的事件驱动架构,单个连接可处理多个并发请求。通过StatefulRedisConnection维护长连接:

RedisClient client = RedisClient.create("redis://localhost");
StatefulRedisConnection<String, String> connection = client.connect();// 异步操作
RedisAsyncCommands<String, String> async = connection.async();
RedisFuture<String> future = async.get("key"); // 同步操作(底层仍是非阻塞)
RedisCommands<String, String> sync = connection.sync();
String value = sync.get("key");

核心特性

  • 连接多路复用(单个连接支持5W+ QPS)
  • 支持响应式编程(Reactive API)
  • 自动拓扑刷新(集群模式)

1.3 Redisson:分布式服务封装

在Redis协议层之上构建分布式对象模型,例如分布式Map的使用:

Config config = new Config();
config.useSingleServer().setAddress("redis://localhost:6379");RedissonClient redisson = Redisson.create(config);
RMap<String, Object> map = redisson.getMap("myMap");
map.put("key", new Object());  // 自动序列化

设计特点

  • 内置30+分布式数据结构
  • 支持Spring Session分布式会话
  • 提供RLock等分布式同步器

2. API设计与使用体验

2.1 基础操作对比

操作类型JedisLettuceRedisson
字符串jedis.set(key,value)commands.set(key,value).await()bucket.set(value)
哈希hset(key,field,val)commands.hset(key,field,val)rMap.put(field, value)

Redisson的API抽象度最高,但学习曲线更陡峭。

2.2 事务与Pipeline支持

Jedis实现Pipeline的典型方式:

Pipeline p = jedis.pipelined();
p.set("k1", "v1");
p.get("k2");
List<Object> results = p.syncAndReturnAll();

Lettuce的异步批处理:

RedisFuture<String> f1 = commands.set("k1", "v1");
RedisFuture<String> f2 = commands.get("k2");
// 手动或通过CompletableFuture组合结果

2.3 异常处理差异

  • Jedis需要显式处理连接异常:
    try {jedis.incr("counter");
    } catch (JedisConnectionException e) {// 重试或告警
    }
    
  • Lettuce通过Future回调处理:
    future.handle((res, ex) -> {if(ex != null) logger.error("操作失败", ex);return res;
    });
    

3. 性能与资源消耗

3.1 基准测试数据(Redis 6.0,8核16G环境)

客户端10线程QPS100线程QPS内存占用(100连接)
Jedis45,00032,000~120MB
Lettuce48,00046,000~80MB
Redisson38,00035,000~200MB

结论:Lettuce在高并发下性能下降最小,Redisson因功能封装有额外开销。

3.2 线程模型对比图

1连接:1线程
1连接:N线程
连接组
Jedis
阻塞IO
Lettuce
Netty EventLoop
Redisson
全局共享

4. 高级功能与生态整合

4.1 分布式锁实现对比

Redisson分布式锁示例:

RLock lock = redisson.getLock("orderLock");
lock.lock(10, TimeUnit.SECONDS);  // 自动续期
try {// 业务逻辑
} finally {lock.unlock();
}

Jedis需手动实现:

String result = jedis.set("lock", "1", "NX", "EX", 10);
if ("OK".equals(result)) {try {// 业务逻辑} finally {jedis.del("lock");}
}

4.2 Spring Boot集成配置

Lettuce配置示例

spring:redis:lettuce:pool:max-active: 16timeout: 200ms

Redisson Spring Starter

@Bean
public RedissonClient redisson() {Config config = new Config();config.useClusterServers().addNodeAddress("redis://127.0.0.1:7001");return Redisson.create(config);
}

5. 选型建议与总结

5.1 决策流程图

遗留系统
新项目?
需要分布式对象?
Redisson
高并发?
Lettuce
Jedis
保持现有客户端

5.2 版本兼容性矩阵

客户端Redis 2.6+Redis 5+特性Redis 6线程IO
Jedis✔️部分支持
Lettuce✔️✔️✔️
Redisson✔️✔️实验性支持

最终建议:对于新项目,若无特殊需求,Lettuce通常是平衡性最佳的选择。


🔥🔥🔥道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

💖The Start💖点点关注,收藏不迷路💖

 <tr><td width="50%"><div align="center"><font color="#E73B3E"><em>💖The Start💖点点关注,收藏不迷路💖<em></em></em></font></div></td></tr></tbody>
</table>

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

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

相关文章

AI问答系统完整架构规划文档

📋 目录 现有代码架构分析 AI核心组件缺口分析 完整技术架构设计 开发路线图 技术实现要点 🏗️ 现有代码架构分析 当前项目结构 ai问答/ ├── main.py # FastAPI服务入口,API路由 ├── model.py # 基础LLM模型加载与推理 ├── rag.py …

圆柱电池自动分选机:全流程自动化检测的革新之路

在新能源产业快速发展的背景下&#xff0c;圆柱电池作为动力电池和储能领域的核心组件&#xff0c;其生产效率与质量把控至关重要。圆柱电池自动分选机的出现&#xff0c;通过全流程自动化检测技术&#xff0c;为电池制造与分选环节提供了高效、精准的解决方案。传统电池分选依…

leetcode 1695. 删除子数组的最大得分 中等

给你一个正整数数组 nums &#xff0c;请你从中删除一个含有 若干不同元素 的子数组。删除子数组的 得分 就是子数组各元素之 和 。返回 只删除一个 子数组可获得的 最大得分 。如果数组 b 是数组 a 的一个连续子序列&#xff0c;即如果它等于 a[l],a[l1],...,a[r] &#xff0c…

netty的编解码器,以及内置的编解码器

一、编码器和解码器 1、什么是编码和解码 解码常用于入站操作&#xff0c;将字节转换为消息。编码用于出站&#xff0c;将消息转换为字节流 2、解码器ByteToMessageDecoder和ReplayingDecoder&#xff0c;ReplayingDecoder扩展了ByteToMessageDecoder类&#xff0c;使得我们不必…

一个基于现代C++智能指针的优雅内存管理解决方案

目录 问题陈述 (Problem Statement) 1.1 问题背景与动机1.2 问题复杂性分析1.3 传统解决方案的局限性1.4 目标需求定义 预备知识 (Preliminaries) 2.1 C智能指针基础2.2 循环引用问题详解2.3 自定义删除器2.4 引用计数机制深入理解 核心解决方案 (Core Solution) 3.1 设计思路…

LabVIEW单片机温控

基于 LabVIEW 与单片机设计温度控制系统&#xff0c;整合硬件电路、串口通信、控制算法及监控功能&#xff0c;适用于教学实验及中小型设备温控场景。系统以低成本实现高精度温控&#xff0c;为同类控制系统设计提供参考。应用场景教学场景&#xff1a;作为自动化专业综合实验项…

【初识数据结构】CS61B中的最小生成树问题

本教程总结CS61B 关于图章节中的最小生成树&#xff08;Minimum Spanning Trees, MST&#xff09;问题&#xff0c;以及对应的的算法什么是最小生成树&#xff08;MST&#xff09; 考虑这样一个问题&#xff0c;给你一个无向图&#xff0c;你能不能找出这个图中的一组边&#x…

vue apk返回键不好使

在 Android 设备上&#xff0c;你可以通过监听物理返回键来实现特定的逻辑。这可以通过在 Vue 组件中添加一个事件监听器来实现&#xff1a;mounted() {this.$once(hook:beforeDestroy, () > {if (document.removeEventListener) {document.removeEventListener(backbutton,…

Ubuntu 22.04 安装 MySQL 8.0 完整步骤文档

1、安装 1.1、下载 cd /usr/local/在 /usr/local/ 下执行&#xff0c;下载资源包&#xff0c;可以本地下载上传 wget https://downloads.mysql.com/archives/get/p/23/file/mysql-8.0.32-linux-glibc2.12-x86_64.tar.xz1.2、解压安装 tar -Jxvf mysql-8.0.32-linux-glibc2.…

Docker,其他机器下载镜像并copy到目标机器导入docker镜像

Docker&#xff0c;其他机器下载镜像并copy到目标机器导入docker镜像源机器 【下载镜像】目标机器slave1 【无法下载镜像】步骤 1&#xff1a;在网络正常的机器&#xff08;cg&#xff09;上下载镜像&#xff0c;导出镜像到指定路径# 1. 下载镜像docker pull ubuntu:20.04# 2.…

基于现代R语言【Tidyverse、Tidymodel】的机器学习方法与案例分析

机器学习已经成为继理论、实验和数值计算之后的科研“第四范式”&#xff0c;是发现新规律&#xff0c;总结和分析实验结果的利器。机器学习涉及的理论和方法繁多&#xff0c;编程相当复杂&#xff0c;一直是阻碍机器学习大范围应用的主要困难之一&#xff0c;由此诞生了Python…

如何将 git 远程 URL 从 https 更改为 ssh

在项目开发中&#xff0c;使用 SSH 连接 Git 仓库可以提高安全性和便利性。本文将指导你如何将 Git 远程 URL 从 HTTPS 更改为 SSH。操作指南步骤 1: 查看当前远程 URL首先&#xff0c;确认当前的远程 URL 使用的是 https。打开终端并输入以下命令&#xff1a;git remote -v如&…

PyCharm 高效入门指南(核心模块详解二)

四、生产力工具集成PyCharm 不仅仅是 Python 编辑器&#xff0c;更是集成了多种开发工具的综合平台。通过内置的生产力工具&#xff0c;开发者可以在一个界面内完成数据库操作、科学计算、远程开发和测试等全流程工作&#xff0c;避免工具切换带来的效率损耗。4.1 数据库工具链…

WebkitSpeechRecognition 语音识别

JavaScript WebkitSpeechRecognition:使用语音识别技术增强 Web 应用程序 WebkitSpeechRecognition 是一种 JavaScript API,它可以让您的 Web 应用程序使用语音识别技术。使用 WebkitSpeechRecognition,您可以让用户通过说话来与您的 Web 应用程序进行交互,这可以使您的应…

CUDA C++核心库(CCCL)

文章目录CUDA C核心库&#xff08;CCCL&#xff09;核心库介绍CUDA C 开发工具的层级范围各层级工具的具体内容Thrust自动内存管理类型安全自定义分配器&#xff08;页锁定内存&#xff09;高级API替代底层操作thrust::transform基本使用几种执行策略iteratorload_cs高效索引md…

MySQL InnoDB存储引擎深度解析:从原理到优化

InnoDB的优势InnoDB之所以成为众多应用的首选&#xff0c;主要得益于以下几个显著优势&#xff1a;事务支持&#xff1a;InnoDB是MySQL中唯一支持ACID&#xff08;原子性、一致性、隔离性、持久性&#xff09;事务的存储引擎。它通过日志和锁机制确保事务的完整性&#xff0c;这…

LLM评测框架Ragas:Natural Language Comparison指标(解决了Ollama推理框架不支持的问题)

Factural Correctness Factural Correctness是事实正确性是评价LLM生成的反馈和reference的事实正确性。该指标用于确定生成的响应与参考文献的一致程度。Factural Correctness取值在0到1之间,越接近于1结果越好。 为了衡量回应和参考文献之间的一致性,该指标使用 LLM 首先将…

HTTP 协议常见字段(请求头/响应头)

HTTP&#xff08;HyperText Transfer Protocol&#xff09;协议通过 请求头&#xff08;Request Headers&#xff09; 和 响应头&#xff08;Response Headers&#xff09; 传递元数据。以下是 最常见的 HTTP 字段 及其作用&#xff1a;1. 通用字段&#xff08;请求和响应均可使…

期货配资软件开发注意事项?

期货配资软件开发 期货配资软件开发涉及多个核心模块&#xff0c;包括资金管理、风险控制、交易接口、用户权限管理等。此类系统需符合金融监管要求&#xff0c;确保资金安全与数据合规。开发过程中需优先考虑高并发、低延迟及系统稳定性。期货资管系统平台搭建方案架构设计 采…

STM32-第十节-DMA直接存储器存取

一、DMA&#xff1a;1.简介&#xff1a;DMA&#xff0c;直接存储区存取DMA可以提供外设和存储器或存储器与存储器见的高速数据传输&#xff0c;无需CPU干预。12个通道&#xff1a;DMA1&#xff08;7个通道&#xff09;&#xff0c;DMA2&#xff08;5个通道&#xff09;每个通道…