Java项目对接redis,客户端是选Redisson、Lettuce还是Jedis?
JAVA项目对接redis,客户端是选Redisson、Lettuce还是Jedis?
- 一、客户端简介
- 1. Jedis介绍
- 2. Lettuce介绍
- 3. Redisson介绍
- 二、横向对比
- 三、选型说明
在实际的项目开发中,对于一个需要对接Redis的项目来说,就面临着选择合适的Redis客户端。目前比较常用的Redis客户端有Redisson、Lettuce和Jedis,两者都有各自的优点和适用场景,本文将对三者进行比较,并给出选择的建议。
📕作者简介:战斧,从事金融IT行业,有着多年一线开发、架构经验;爱好广泛,乐于分享,致力于创作更多高质量内容
📗本文收录于 Redis专栏 专栏,有需要者,可直接订阅专栏实时获取更新
📘高质量专栏 云原生、RabbitMQ、Spring全家桶 等仍在更新,欢迎指导
📙Zookeeper Redis kafka docker netty等诸多框架,以及架构与分布式专题即将上线,敬请期待
一、客户端简介
1. Jedis介绍
Jedis
代码仓库地址:https://github.com/redis/jedis 。它是Redis对Java语言所推出的官方
客户端,可见下图
Jedis的主要特点如下:
-
简洁高效:Jedis的设计简洁高效,性能较好,可以通过直接发送命令字符串与Redis进行通信,适用于对Redis的原生命令操作更为关注的场景。
-
社区活跃:Jedis是最早的Java Redis客户端,拥有庞大的用户社区和完善的文档支持,可以方便地获取到各种使用案例和问题解答。
-
支持大部分特性:Jedis支持Redis的大部分特性,如事务、流水线、发布/订阅等,可以满足绝大多数的需求。
简而言之,作为官方客户端,各种命令及功能的支持自然是齐全的,社区及文档的支持也是最完善的
。
2. Lettuce介绍
Lettcue
代码仓库地址:https://github.com/redis/lettuce 。自从Lettcue
并入Redis官方后(如下新闻),我们可以说Jedis是长子,Lettcue就是次子,也成为了官方推荐的客户端。
Lettuce主打高性能,它的主要特点如下:
-
异步IO:Lettuce使用异步IO和非阻塞IO模型,可以在一个线程中处理多个并发请求,提供了更好的并发能力和响应速度。它使用了Netty作为底层网络通信框架,充分利用了Netty的高性能和可扩展性。
-
响应式编程:Lettuce支持响应式编程模式,使用Reactive Streams来处理异步数据流。通过使用响应式编程,可以简化异步编程的复杂性,提供了更加灵活和可组合的方式来处理Redis的响应。
-
连接池:Lettuce内置了连接池功能,可以管理和复用Redis的连接,提供了更好的连接管理和资源利用。连接池可以有效地减少连接的创建和销毁开销,提高了系统的性能和稳定性。
-
高可用和集群支持:Lettuce支持Redis的高可用和集群模式,提供了自动的节点发现和故障转移功能。它可以自动检测集群的拓扑结构,并在节点故障时进行自动切换,保证数据的可用性和持久性。
-
扩展性和灵活性:Lettuce提供了丰富的功能和API,可以满足各种不同的需求。它支持事务、管道、发布-订阅等特性,还提供了对Redis Sentinel、Redis Cluster和Redis Streams等功能的支持。同时,Lettuce也支持自定义的扩展,可以方便地进行功能扩展和定制开发。
简而言之,相比Jedis,Lettuce提升了性能,丰富了功能,对于开发者来说就减少了自己造轮子
。
3. Redisson介绍
Redisson
代码仓库地址:https://github.com/redisson/redisson 。虽然并不是官方客户端,但是其热度却超过了上述两个‘亲儿子’
Redisson主打功能丰富,它的主要特点如下:
-
分布式对象:Redisson支持将Java对象存储在Redis中,以及在分布式环境中进行操作和调用。这使得开发人员可以更方便地使用常规的面向对象编程方式来处理分布式数据。
-
分布式集合:Redisson提供了一系列分布式集合数据结构,比如Set、List、Queue、Deque、Map等。这些数据结构可以在分布式环境中进行操作和处理,使得开发人员能够更方便地实现分布式应用。
-
分布式锁:Redisson提供了一种分布式锁的实现,支持公平锁和非公平锁两种模式。这使得开发人员可以更容易地实现分布式环境下的并发控制,避免数据竞争和资源争用。
-
分布式调度器:Redisson提供了一种分布式调度器的实现,可以让开发人员在分布式环境中进行任务调度和定时任务的管理。这使得分布式应用的任务调度更加方便和灵活。
-
集群支持:Redisson支持Redis的集群模式,可以轻松地在Redis集群中进行数据操作和处理。这使得Redisson能够处理大规模的数据量和高并发的请求。
简而言之,相比前两者,Redisson提供了更多贴近业务的功能,在性能上也做了优化
。
二、横向对比
看完三大客户端的特点,其实不难发现针对Redis的基础用法是大家都有的,重点就是是否内置“高级功能”,以及对“连接性能”的追求。Jedis
的主要不足在于它不支持异步和响应式API;Lettuce
有高性能的异步和响应式API,但在“高级功能”(如分布式功能)方面的支持相对有限,Redisson
则有很多高级功能也做了连接优化,但也因此比较复杂臃肿,处理简单的Redis操作时反倒浪费了一些性能。它们的部分特性对比如下:
特性 | Redisson | Lettuce | Jedis |
---|---|---|---|
异步IO | 是 | 是 | 否 |
非阻塞IO | 是 | 是 | 否 |
连接池 | 是 | 是 | 是 |
分布式锁 | 是 | 否 | 否 |
分布式集合 | 是 | 否 | 否 |
哨兵模式 | 是 | 是 | 是 |
主从复制 | 是 | 是 | 是 |
集群模式 | 是 | 是 | 是 |
性能 | 高 | 高 | 一般 |
功能丰富性 | 非常丰富 | 较丰富 | 基本 |
学习曲线 | 较陡 | 适中 | 简单 |
社区支持 | 相对较多 | 相对较多 | 相对较多 |
综合对比来看,Redisson在功能丰富性和性能方面都具有优势,适用于对分布式对象和服务有更高要求的项目。Lettuce在性能方面表现优秀,适合对并发能力和响应速度有较高要求的项目。Jedis虽然简单易用,但在性能和功能方面相对较弱。
三、选型说明
作为架构选型,我们必须清楚,选出一个完美的方案几乎不可能。更多的时候,架构只是排除掉那些不符合要求的方案,然后在剩下的方案中,选一个不那么差的,就成了所谓的“最佳实践”。因此在选型之前,我们必须明确自己当前的需求,按需来选。以我们自己的某个项目来说,引入Redis主要就是两方面的作用:
- 固定-复杂数据的分布式缓存
有一些计算非常复杂,但用的又比较频繁,如果用到了就去算一遍非常耗时,因此把结果缓存至Redis,供各业务获取 - 分布式锁
有些业务运行时,其他相关业务需要锁定为不可操作,需要使用分布式锁
针对项目要对接Redis的场景,我们可以根据以下因素进行选择:
接下来,就是分析支持情况,选择Redis做缓存是一个比较基础的功能,各个客户端都能比较简单的实现这个功能。而对于分布式锁其实场景比较复杂,使用 Jedis 或 Lettuce也都能实现,但需要我们自己写不少代码来完善场景。 而 Redisson 本身就实现了比较完备的分布式锁功能,比如支持RedLock算法,读写锁,上锁后自动续期的 watchDog 功能。所以开发者可以直接使用现成的功能。
所以在我们项目这种场景下,选择 Redisson
几乎成了必然,事实上用Redis做分布式锁,Redisson确实是最强大而省事的,这也正是 Redisson 比官方客户端人气还高的重要因素。当然如果你的项目对接redis,纯为了当缓存用,既没有高并发也没有复杂场景,使用
Lettuce
也是可以的。至于Jedis
则太简单了,不支持NIO,性能上也稍弱,一旦后续有些复杂的业务,还需要我们手动去改,新项目的话就不推荐再用了。
相关文章:

Java项目对接redis,客户端是选Redisson、Lettuce还是Jedis?
JAVA项目对接redis,客户端是选Redisson、Lettuce还是Jedis? 一、客户端简介1. Jedis介绍2. Lettuce介绍3. Redisson介绍 二、横向对比三、选型说明 在实际的项目开发中,对于一个需要对接Redis的项目来说,就面临着选择合适的Redis客…...

AngularJS Web前端框架:深入探索与应用实践
AngularJS Web前端框架:深入探索与应用实践 AngularJS,作为一款强大的Web前端框架,为开发者提供了丰富的功能和工具,使得构建复杂且交互性强的Web应用变得更为便捷。本文将从四个方面、五个方面、六个方面和七个方面对AngularJS进…...

SQL 入门:使用 MySQL 进行数据库操作
SQL 入门:使用 MySQL 进行数据库操作 目录 引言SQL 基础 SQL 语言概述MySQL 简介 数据库设计基础 数据库与表的设计常见数据类型 MySQL 安装与配置 安装 MySQL基本配置与连接 基本 SQL 语句 数据库的创建与删除表的创建、修改与删除数据插入、更新与删除 数据查询…...

window安装ffmpeg播放本地摄像头视频
1、安装ffmpeg ffmpeg官方网站:FFmpeg 下载后解压文件夹名为ffmpeg 2、设置环境变量 目录 1、安装ffmpeg 设置环境变量 以F:\software\after\ffmpeg\bin为例 在命令行中输入ffmpeg出现下方代表安装成功 3、通过ffmpeg播放本地电脑摄像头 鼠标右击开始按钮&…...

【嵌入式DIY实例】-OLED显示网络时钟
OLED显示网络时钟 文章目录 OLED显示网络时钟1、硬件准备与接线2、代码实现在上一个ESP8266 NodeMCU文章中,我们用DS3231 RTC芯片和SSD1306 OLED制作了一个简单的实时时钟,时间和日期显示在SSD1306屏幕上,并且可以通过两个按钮进行设置。 在本中,我们将使用ESP 8266 NodeMC…...

【线程相关知识】
今日内容概要 开启线程的两种方式TCP服务端实现并发效果线程对象的join方法线程间数据共享线程对象属性及其他方法守护线程线程互斥锁GIL全局解释器锁多进程与多线程的实际应用场景 今日内容详细 开启线程的两种方式 # import time # from multiprocessing import Process #…...

鸿蒙ArkTS声明式开发:跨平台支持列表【透明度设置】 通用属性
透明度设置 设置组件的透明度。 说明: 开发前请熟悉鸿蒙开发指导文档: gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。 从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版…...

【SQL学习进阶】从入门到高级应用(九)
文章目录 子查询什么是子查询where后面使用子查询from后面使用子查询select后面使用子查询exists、not existsin和exists区别 union&union alllimit 🌈你好呀!我是 山顶风景独好 💕欢迎来到我的博客,很高兴能够在这里和您见面…...

Web前端三大主流框架技术分享
在当今快速发展的互联网时代,Web前端技术作为连接用户与服务的桥梁,其重要性不言而喻。随着技术的不断进步,为了提升开发效率、优化用户体验,一系列强大的前端框架应运而生。其中,Angular、React和Vue.js作为当前最为主…...

dockers安装mysql
1.dockerhub上搜索自己需要安装得镜像版本 dockerhub网址:https://hub-stage.docker.com docker pull mysql:5.7 #下载自己需要得版本2.启动容器实例,并且挂载容器数据卷 docker run -d -p 3306:3306 --privilegedtrue \ -v /home/mysql/log:/var/log/…...

100道面试必会算法-27-美团2024面试第一题-前缀和矩阵
100道面试必会算法-27-美团2024面试第一题-前缀和矩阵 问题解读 给定一个 n x n 的二进制矩阵,每个元素是 0 或 1。我们的任务是计算矩阵中所有边长为 k 的子矩阵中,包含特定数量 1 的情况。例如,我们希望找到所有边长为 k 的子矩阵中包含 k…...

从摇一摇到弹窗,AD无处不在?为了不再受打扰,推荐几款好用的屏蔽软件,让手机电脑更清爽
当我们沉浸在智能手机带来的便捷与乐趣中时,内置AD如同不速之客,时常打断我们的体验。 尤其是手机上那些“摇一摇”跳转,稍有不慎就会跳转到其他应用,令人不胜其烦。同样,电脑上的内置AD也如影随形,影响了我…...

HackTheBox-Machines--Nibbles
Nibbles 测试过程 1 信息收集 NMAP 80 端口 网站出了打印出“Hello world!”外,无其他可利用信息,但是查看网页源代码时,发现存在一个 /nibbleblog 文件夹 检查了 http://10.129.140.63/nibbleblog/ ,发现了 /index.p…...

东方博宜1703 - 小明买水果
问题描述 小明去超市买了若干斤水果,你能根据水果的单价,小明买的水果数量,编一个程序计算出总金额,并打印出清单。 输入 输入两个值, 第一个为商品的单价,是一个小数。 第二个为商品的数量,…...

mac电脑用谷歌浏览器对安卓手机H5页面进行inspect
1、mac上在谷歌浏览器上输入 chrome://inspect 并打开该页面。 2、连接安卓手机到Mac电脑:使用USB数据线将安卓手机连接到Mac电脑。 3、手机上打开要的h5页面 Webview下面选择要的页面,点击inspect,就能像谷歌浏览器页面打开下面的页面&#…...

动手学深度学习(Pytorch版)代码实践-深度学习基础-01基础函数的使用
01基础函数的使用 主要内容 张量操作:创建和操作张量,包括重塑、填充、逐元素操作等。数据处理:使用pandas加载和处理数据,包括处理缺失值和进行one-hot编码。线性代数:包括矩阵运算、求和、均值、点积和各种范数计算…...

vm-bhyve:bhyve虚拟机的管理系统@FreeBSD
先说情况,当前创建虚拟机后网络没有调通....不明白是最近自己点背,还是确实有难度... 缘起: 前段时间学习bhyve虚拟机,发现bvm这个虚拟机管理系统,但是实践下来发现网络方面好像有问题,至少我花了两天时间…...

【Java】刚刚!突然!紧急通知!垃圾回收!
【Java】刚刚!突然!紧急通知!垃圾回收! 文章目录 【Java】刚刚!突然!紧急通知!垃圾回收!从C语言的内存管理引入:手动回收Java的垃圾回收机制引用计数器循环引用问题 可达…...

[Algorithm][动态规划][子序列问题][最长递增子序列][摆动序列]详细讲解
目录 0.子序列 vs 子数组1.最长递增子序列1.题目链接2.算法原理详解3.代码实现 2.摆动序列1.题目链接2.题目链接3.代码实现 0.子序列 vs 子数组 子序列: 相对顺序是跟源字符串/数组是一致的但是元素和元素之间,在源字符串/数组中可以是不连续的一般时间…...

【稳定检索】2024年心理学与现代化教育、媒体国际会议(PMEM 2024)
2024年心理学与现代化教育、媒体国际会议 2024 International Conference on Psychology and Modern Education and Media 【1】会议简介 2024年心理学与现代化教育、媒体国际会议即将召开,这是一场汇聚全球心理学、教育及媒体领域精英的学术盛宴。 本次会议将深入探…...

深入了解diffusion model
diffusion model是如何运作的 会输入当时noise的严重程度,根据我们的输入来确定在第几个step,并做出不同的回应。 Denoise模组内部实际做的事情 产生一张图片和产生noise难度是不一样的,若denoise 模块产生一只带噪声的猫说明这个模块已经会…...

TransmittableThreadLocal原理
1、原理 TransmittableThreadLocal(简称TTL)是阿里巴巴开源的一个Java库,用于解决线程池中线程本地变量传递的问题。其底层原理主要是基于Java的ThreadLocal机制并对其进行扩展,以支持在父子线程间以及线程池中任务切换时&#x…...

华为昇腾310B初体验,OrangePi AIpro开发板使用测评
0、写在前面 很高兴收到官方的OrangePi AIpro开发板测试邀请,在过去的几年中,我在自己的博客写了一系列有关搭载嵌入式Linux系统的SBC(单板计算机)的博文,包括树莓派4系列、2K1000龙芯教育派、Radxa Rock5B、BeagleBo…...

GPTQ 量化大模型
GPTQ 量化大模型 GPTQ 算法 GPTQ 算法由 Frantar 等人 (2023) 提出,它从 OBQ 方法中汲取灵感,但进行了重大改进,可以将其扩展到(非常)大型的语言模型。 步骤 1:任意顺序量化 OBQ 方法选择权重按特定顺序…...

【GD32】05 - PWM 脉冲宽度调制
PWM PWM (Pulse Width Modulation) 是一种模拟信号电平的方法,它通过使用数字信号(通常是方波)来近似地表示模拟信号。在PWM中,信号的占空比(即高电平时间占整个周期的比例)被用来控制平均输出电压或电流。…...

JVM思维导图
帮助我们快速整理和总结JVM相关知识,有结构化认识和整体的思维模型 JVM相关详细知识和面试题...

Ollama+OpenWebUI+Phi3本地大模型入门
文章目录 Ollama+OpenWebUI+Phi3本地大模型入门一、基础环境二、Ollama三、OpenWebUI + Phi3Ollama+OpenWebUI+Phi3本地大模型入门 完全不懂大模型的请绕道,相信我李一舟的课程比较适合 Ollama提供大模型运行环境,OpenWebUI提供UI,Phi3就是那个大模型。 当然,Ollama支持超级…...

实战15:bert 命名实体识别、地址解析、人名电话地址抽取系统-完整代码数据
直接看项目视频演示: bert 命名实体识别、关系抽取、人物抽取、地址解析、人名电话地址提取系统-完整代码数据_哔哩哔哩_bilibili 项目演示: 代码: import re from transformers import BertTokenizer, BertForTokenClassification, pipeline import os import torch im…...

js 表格添加|删除一行交互
一、需求 二、实现 <div style"margin-bottom: 55px"><form action"" method"post" enctype"multipart/form-data" id"reportForm" name"sjf" style"margin-left: 25px;margin-bottom: 50px;&quo…...

如何选择合适的服务器硬件和配置?
业务需求 了解您的业务需求和负载。这将帮助您确定需要哪种类型的服务器(如文件服务器、数据库服务器、Web服务器等)以及所需的处理能力、内存、存储和网络性能。...