Redis客户端Jedis、Lettuce 和 Redisson优缺点总结

embedded/2025/3/19 8:45:54/

https://developer.huawei.com/consumer/cn/blog/topic/03825550899620047

Redis 官方推荐的 Java 客户端有Jedis、Lettuce 和 Redisson。本文总结这些客服端的优缺点

1. Jedis

Jedis 是老牌的 Redis 的 Java 实现客户端,提供了比较全面的 Redis 命令的支持,其官方网址是:https://github.com/redis/jedis

优点:

  • 支持全面的 Redis 操作特性(可以理解为API比较全面)。
  • 老牌的redis客户端,使用很稳定; spring-boot 1.x 默认使用jedis;

缺点:

  • 使用阻塞的 IO,且其方法调用都是同步的,程序流需要等到 sockets 处理完 IO 才能执行,不支持异步;
  • Jedis 客户端实例不是线程安全的,所以需要通过连接池来使用 Jedis。

2. Lettuce

Lettuce是一种可扩展的线程安全的 Redis 客户端,支持异步模式。如果避免阻塞和事务操作,如BLPOP和MULTIEXEC,多个线程就可以共享一个连接。Lettuce 底层基于 Netty,支持高级的 Redis 特性,比如哨兵,集群,管道,自动重新连接和Redis数据模型。Lettuce 的官网地址是:https://github.com/lettuce-io/lettuce-core

优点:

  • 支持同步异步通信模式;
  • Lettuce 的 API 是线程安全的,如果不是执行阻塞和事务操作,如BLPOP和MULTIEXEC,多个线程就可以共享一个连接;
  • spring-boot 2.x 默认使用Lettuce;

3. Redisson

Redisson 是一个在 Redis 的基础上实现的 Java 驻内存数据网格(In-Memory Data Grid)。它不仅提供了一系列的分布式的 Java 常用对象,还提供了许多分布式服务。其中包括( BitSet, Set, Multimap, SortedSet, Map, List, Queue, BlockingQueue, Deque, BlockingDeque, Semaphore, Lock, AtomicLong, CountDownLatch, Publish / Subscribe, Bloom filter, Remote service, Spring cache, Executor service, Live Object service, Scheduler service) Redisson 提供了使用Redis 的最简单和最便捷的方法。Redisson 的宗旨是促进使用者对Redis的关注分离(Separation of Concern),从而让使用者能够将精力更集中地放在处理业务逻辑上。Redisson的官方网址是:https://redisson.org/

优点:

  • 使用者对 Redis 的关注分离,可以类比 Spring 框架,这些框架搭建了应用程序的基础框架和功能,提升开发效率,让开发者有更多的时间来关注业务逻辑;
  • 提供很多分布式相关操作服务,例如,分布式锁,分布式集合,可通过Redis支持延迟队列等。

缺点:

  • Redisson 对字符串的操作支持比较差。

4. 使用建议

一般是采用如下搭配组合。

  • Jedis + Redisson
  • Lettuce + Redisson

http://www.ppmy.cn/embedded/173810.html

相关文章

总结 kotlin中的关键字和常用方法

Kotlin 的关键字分为 硬关键字(Hard Keywords)、软关键字(Soft Keywords) 和 修饰符关键字(Modifier Keywords)。以下是分类整理的关键字列表及其核心用途: 1. 硬关键字(Hard Keywor…

【数据库】如何用索引优化查询性能

引言 在数据库查询中,索引是提升性能的关键工具。合理使用索引可以显著减少数据扫描量,加快查询速度。然而,索引的使用也需要谨慎,错误的索引策略可能导致性能下降甚至系统崩溃。本文将深入探讨如何通过索引优化查询性能&#xf…

函数(函数的概念、库函数、自定义函数、形参和实参、return语句、数组做函数参数、嵌套调用和链式访问、函数的声明和定义、static和extern)

一、函数的概念 •C语⾔中的函数:⼀个完成某项特定的任务的⼀⼩段代码 •函数又被翻译为子函数(更准确) •在C语⾔中我们⼀般会⻅到两类函数:库函数 ⾃定义函数 二、库函数 1 .标准库和头文件 •C语⾔的国际标准ANSIC规定了⼀…

硬件设计抽象级别详解:门级、RTL级、行为级与HLS

硬件设计抽象级别详解:门级、RTL级、行为级与HLS 引言 在数字系统设计领域,硬件描述语言(HDL)提供了多种抽象级别来描述电路功能和结构。从最底层的门级描述到高层的行为级描述,每一种抽象级别都有其特定的用途和优势。理解这些不同级别以及…

Trae AI 能力:开启跨系统开发新时代,让远程协作与定制化开发触手可及

目录 前言 Trae 国内版:AI 原生 IDE 的新突破 1. Builder 模式:从自然语言到代码的“零摩擦”开发 2. 上下文深度感知:更懂代码的智能伙伴 3. 实时代码智能补全:让编码速度“质变” 4. AI 协作:跨模块开发与实时…

Z 轴热膨胀系数:PCB 可靠性的关键因素与选材策略

在电子设备小型化与高性能化的趋势下,PCB(印刷电路板)的可靠性成为决定产品寿命的核心因素。其中,Z 轴热膨胀系数(α2/z-CTE)作为板材的关键参数,直接影响多层板的层间结合力、焊点稳定性及整体…

PostgreSQL的学习心得和知识总结(一百七十一)|深入理解PostgreSQL数据库之 外连接消除 的使用和实现

目录结构 注:提前言明 本文借鉴了以下博主、书籍或网站的内容,其列表如下: 1、参考书籍:《PostgreSQL数据库内核分析》 2、参考书籍:《数据库事务处理的艺术:事务管理与并发控制》 3、PostgreSQL数据库仓库…

Android Fresco 框架工具与测试模块源码深度剖析(五)

一、引言 在 Android 开发中,Fresco 是一个强大的图片加载和显示框架,由 Facebook 开源。它不仅提供了高效的图片加载和缓存机制,还配备了丰富的工具与测试模块,这些模块对于开发者在调试、优化以及确保框架的正确性方面起着至关…