Java项目对接redis,客户端是选Redisson、Lettuce还是Jedis?

news2025/1/22 9:21:27

JAVA项目对接redis,客户端是选Redisson、Lettuce还是Jedis?

在这里插入图片描述

在实际的项目开发中,对于一个需要对接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的主要特点如下:

  1. 简洁高效:Jedis的设计简洁高效,性能较好,可以通过直接发送命令字符串与Redis进行通信,适用于对Redis的原生命令操作更为关注的场景。

  2. 社区活跃:Jedis是最早的Java Redis客户端,拥有庞大的用户社区和完善的文档支持,可以方便地获取到各种使用案例和问题解答。

  3. 支持大部分特性:Jedis支持Redis的大部分特性,如事务、流水线、发布/订阅等,可以满足绝大多数的需求。

简而言之,作为官方客户端,各种命令及功能的支持自然是齐全的,社区及文档的支持也是最完善的

2. Lettuce介绍

Lettcue代码仓库地址:https://github.com/redis/lettuce 。自从Lettcue并入Redis官方后(如下新闻),我们可以说Jedis是长子,Lettcue就是次子,也成为了官方推荐的客户端。

在这里插入图片描述
Lettuce主打高性能,它的主要特点如下:

  1. 异步IO:Lettuce使用异步IO和非阻塞IO模型,可以在一个线程中处理多个并发请求,提供了更好的并发能力和响应速度。它使用了Netty作为底层网络通信框架,充分利用了Netty的高性能和可扩展性。

  2. 响应式编程:Lettuce支持响应式编程模式,使用Reactive Streams来处理异步数据流。通过使用响应式编程,可以简化异步编程的复杂性,提供了更加灵活和可组合的方式来处理Redis的响应。

  3. 连接池:Lettuce内置了连接池功能,可以管理和复用Redis的连接,提供了更好的连接管理和资源利用。连接池可以有效地减少连接的创建和销毁开销,提高了系统的性能和稳定性。

  4. 高可用和集群支持:Lettuce支持Redis的高可用和集群模式,提供了自动的节点发现和故障转移功能。它可以自动检测集群的拓扑结构,并在节点故障时进行自动切换,保证数据的可用性和持久性。

  5. 扩展性和灵活性:Lettuce提供了丰富的功能和API,可以满足各种不同的需求。它支持事务、管道、发布-订阅等特性,还提供了对Redis Sentinel、Redis Cluster和Redis Streams等功能的支持。同时,Lettuce也支持自定义的扩展,可以方便地进行功能扩展和定制开发。

简而言之,相比Jedis,Lettuce提升了性能,丰富了功能,对于开发者来说就减少了自己造轮子

3. Redisson介绍

Redisson代码仓库地址:https://github.com/redisson/redisson 。虽然并不是官方客户端,但是其热度却超过了上述两个‘亲儿子’

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Redisson主打功能丰富,它的主要特点如下:

  1. 分布式对象:Redisson支持将Java对象存储在Redis中,以及在分布式环境中进行操作和调用。这使得开发人员可以更方便地使用常规的面向对象编程方式来处理分布式数据。

  2. 分布式集合:Redisson提供了一系列分布式集合数据结构,比如Set、List、Queue、Deque、Map等。这些数据结构可以在分布式环境中进行操作和处理,使得开发人员能够更方便地实现分布式应用。

  3. 分布式锁:Redisson提供了一种分布式锁的实现,支持公平锁和非公平锁两种模式。这使得开发人员可以更容易地实现分布式环境下的并发控制,避免数据竞争和资源争用。

  4. 分布式调度器:Redisson提供了一种分布式调度器的实现,可以让开发人员在分布式环境中进行任务调度和定时任务的管理。这使得分布式应用的任务调度更加方便和灵活。

  5. 集群支持:Redisson支持Redis的集群模式,可以轻松地在Redis集群中进行数据操作和处理。这使得Redisson能够处理大规模的数据量和高并发的请求。

简而言之,相比前两者,Redisson提供了更多贴近业务的功能,在性能上也做了优化

二、横向对比

看完三大客户端的特点,其实不难发现针对Redis的基础用法是大家都有的,重点就是是否内置“高级功能”,以及对“连接性能”的追求。Jedis的主要不足在于它不支持异步和响应式API;Lettuce有高性能的异步和响应式API,但在“高级功能”(如分布式功能)方面的支持相对有限,Redisson则有很多高级功能也做了连接优化,但也因此比较复杂臃肿,处理简单的Redis操作时反倒浪费了一些性能。它们的部分特性对比如下:

特性RedissonLettuceJedis
异步IO
非阻塞IO
连接池
分布式锁
分布式集合
哨兵模式
主从复制
集群模式
性能一般
功能丰富性非常丰富较丰富基本
学习曲线较陡适中简单
社区支持相对较多相对较多相对较多

综合对比来看,Redisson在功能丰富性和性能方面都具有优势,适用于对分布式对象和服务有更高要求的项目。Lettuce在性能方面表现优秀,适合对并发能力和响应速度有较高要求的项目。Jedis虽然简单易用,但在性能和功能方面相对较弱。

三、选型说明

作为架构选型,我们必须清楚,选出一个完美的方案几乎不可能。更多的时候,架构只是排除掉那些不符合要求的方案,然后在剩下的方案中,选一个不那么差的,就成了所谓的“最佳实践”。因此在选型之前,我们必须明确自己当前的需求,按需来选。以我们自己的某个项目来说,引入Redis主要就是两方面的作用:

  1. 固定-复杂数据的分布式缓存
    有一些计算非常复杂,但用的又比较频繁,如果用到了就去算一遍非常耗时,因此把结果缓存至Redis,供各业务获取
  2. 分布式锁
    有些业务运行时,其他相关业务需要锁定为不可操作,需要使用分布式锁
    针对项目要对接Redis的场景,我们可以根据以下因素进行选择:

接下来,就是分析支持情况,选择Redis做缓存是一个比较基础的功能,各个客户端都能比较简单的实现这个功能。而对于分布式锁其实场景比较复杂,使用 Jedis 或 Lettuce也都能实现,但需要我们自己写不少代码来完善场景。 而 Redisson 本身就实现了比较完备的分布式锁功能,比如支持RedLock算法,读写锁,上锁后自动续期的 watchDog 功能。所以开发者可以直接使用现成的功能。

所以在我们项目这种场景下,选择 Redisson 几乎成了必然,事实上用Redis做分布式锁,Redisson确实是最强大而省事的,这也正是 Redisson 比官方客户端人气还高的重要因素。当然如果你的项目对接redis,纯为了当缓存用,既没有高并发也没有复杂场景,使用
Lettuce 也是可以的。至于Jedis则太简单了,不支持NIO,性能上也稍弱,一旦后续有些复杂的业务,还需要我们手动去改,新项目的话就不推荐再用了。

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

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

相关文章

G4 - 可控手势生成 CGAN

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 目录 代码总结与心得 代码 关于CGAN的原理上节已经讲过,这次主要是编写代码加载上节训练后的模型来进行指定条件的生成 图像的生成其实只需要使用…

unity2020打包webGL时卡进程问题

我使用的2020.3.0f1c1,打包发布WEB版的时候会一直卡到asm2wasm.exe这个进程里,而且CPU占用率90%以上。 即使是打包一个新建项目的空场景也是同样的问题,我尝试过一直卡在这里会如何,结果还真打包成功了。只是打包一个空场景需要20…

下载HF AutoTrain 模型的配置文件

下载HF AutoTrain 模型的配置文件 一.在huggingface上创建AutoTrain项目二.通过HF用户名和autotrain项目名,拼接以下url,下载模型列表(json格式)到指定目录三.解析上面的json文件、去重、批量下载模型配置文件(权重以外的文件) 一.在huggingface上创建AutoTrain项目 二.通过HF用…

微信公众号【原子与分子模拟】: 熔化温度 + 超导电性 + 电子化合物 + 分子动力学模拟 + 第一性原理计算 + 数据处理程序

往期内容主要涵盖: 熔化温度 超导电性 电子化合物 分子动力学模拟 第一性原理计算 数据处理程序 【1】熔化温度 分子动力学 LAMMPS 相关内容 【文献分享】分子动力学模拟 LAMMPS 熔化温度 晶体缺陷 熔化方法 LAMMPS 文献:金属熔化行为的局域…

Mac安装第三方软件的命令安装方式

场景: 打开终端命令行,sudo xattr -rd com.apple.quarantine,注意最后quarantine 后面加一个空格!然后打开Finder(访达),点击左侧的 应用程序,找到相关应用,拖进终端qua…

HackTheBox-Machines--Bashed

Bashed 测试过程 1 信息收集 NMAP 80 端口 目录扫描 http://10.129.155.171/dev/phpbash.min.php http://10.129.155.171/dev/phpbash.php 半交互式 shell 转向 交互式shell python -c import socket,subprocess,os;ssocket.socket(socket.AF_INET,socket.SOCK_STREAM);s.co…

dmdts连接kingbase8报错

dmdts连接kingbase报错 环境介绍1 人大金仓jdbc配置2 dmdts 人大金仓jdbc默认配置3 dmdts 修改jdbc配置4 达梦产品学习使用列表 环境介绍 dts版本 使用dmdts连接kingbase金仓数据库报错 无效的URL 对比jdbc连接串,修改配置解决 1 人大金仓jdbc配置 配置URL模版信息等 类名…

深度学习聚类再升级!新算法实现强悍性能,准确率超98%

深度聚类不仅继承了传统聚类算法的优点,在对高维和非线性数据的处理能力,以及自适应性和抗噪性方面也具有很大优势。 具体来说,结合深度学习的聚类算法通过利用深度神经网络的强大特征提取能力,自动学习和识别数据中的复杂结构和…

【小白专用24.5.30已验证】Composer安装php框架thinkPHP6的安装教程

一、框架介绍 1、框架简介和版本选择 Thinkphp是一种基于php的开源web应用程序开发框架ThinkPHP框架,是免费开源的、轻量级的、简单快速且敏捷的php框架。你可以免费使用TP框架,甚至可以将你的项目商用; ThinkPHP8.0 是目前框架正式版的最新版…

Spring 框架:Java 企业级开发的基石

文章目录 序言Spring 框架的核心概念Spring 框架的主要模块Spring Boot:简化 Spring 开发Spring Cloud:构建微服务架构实际案例分析结论 序言 Spring 框架自 2002 年发布以来,已经成为 Java 企业级开发的标准之一。它通过提供全面的基础设施…

家政预约小程序10公众号集成

目录 1 使用测试号3 工作流配置4 配置关注事件脚本5 注册开放平台6 获取公众号access_token6 实现关注业务逻辑总结 我们本次实战项目构建的相当于一个预约平台,既有家政企业,也有家政服务人员还有用户。不同的人员需要收到不同的消息,比如用…

11- Redis 中的 SDS 数据结构

字符串在 Redis 中是很常用的,键值对中的键是字符串类型,值有时也是字符串类型。 Redis 是用 C 语言实现的,但是它没有直接使用 C 语言的 char* 字符数组来实现字符串,而是自己封装了一个名为简单动态字符串(simple d…

基于强化学习的控制率参数自主寻优

1.介绍 针对控制建模与设计场景中控制参数难以确定的普遍问题,提出了一种基于强化学习的控制律参数自主优化解决方案。该方案以客户设计的控制律模型为基础,根据自定义的控制性能指标,自主搜索并确定最优的、可状态依赖的控制参数组合。 可…

ToDesk提示会话数通道限制 - 解决方案及兑惠码分享

如果您最近在体验ToDesk这款远程操控工具时,遇到了提示信息告知“高速通道服务已到期”或“会话数受限”,这表明您本月享受的免费额度——即120小时的使用时间和最多300次的连接机会——已经耗尽。为了解锁无限制的使用时长与连接次数,建议您…

自动驾驶中的长尾问题

自动驾驶中的长尾问题 定义 长尾问题(Long-Tail Problem)是指在数据分布中,大部分的数据集中在少数类别上,而剩下的大多数类别却只有少量的数据。这种数据分布不平衡的现象在许多实际应用中广泛存在,特别是在自动驾驶…

20240531在飞凌的OK3588-C开发板上跑原厂的Buildroot测试USB摄像头

20240531在飞凌的OK3588-C开发板上跑原厂的Buildroot测试USB摄像头 2024/5/31 20:04 USB摄像头分辨率:1080p(1920x1080) 默认编译Buildroot的SDK即可点亮USB摄像头。v4l2-ctl --list-devices v4l2-ctl --list-formats-ext -d /dev/video74 …

双指针法 ( 快乐数 )

「快乐数」 定义为: 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。如果这个过程 结果为 1,那么这个数就是快乐数 编写一个算法来判断一个…

linux /www/server/cron内log文件占用空间过大,/www/server/cron是什么内容,/www/server/cron是否可以删除

linux服务器长期使用宝塔自带计划任务,计划任务执行记录占用服务器空间过大,导致服务器根目录爆满,需要长期排查并删除 /www/server/cron 占用空间过大问题处理 /www/server/cron是什么内容?/www/server/cron是否可以删除&#xf…

基于VGG16使用图像特征进行迁移学习的时装推荐系统

前言 系列专栏:【深度学习:算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域,讨论了各种复杂的深度神经网络思想,如卷积神经网络、循环神经网络、生成对…