Redis--19--常用的redis客户端Jedis 、Lettuce 、Redisson 介绍以及对比

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


redis客户端简介

在实际的项目开发中,对于一个需要对接Redis的项目来说,就面临着选择合适的Redis客户端。目前比较常用的Redis客户端有Redisson、Lettuce和Jedis,两者都有各自的优点和适用场景

1.redis客户端

什么是客户端

  • 介绍之前我们先来了解一下什么是客户端。客户端——即真正的使用者,比如进入redis命令操作有一个redis-cli,这其实就是redis提供的一个基于操作系统(linux、windows)的客户端,此时的使用者是电脑,电脑通过这个客户端可以连接redis并操作redis。同理,在java中如果想要要操作redis同样需要客户端来与redis建立连接。

常用redis客户端

  • 基于redis开放的通信协议,大神们纷纷开发出了各种语言的redis客户端,包括C、C++、C#、D、java、Python、Ruby等50多种,这些客户端都是基于redis命令做了一层封装,并打包成工具,以便更方便地操作redis。
  • ps:SpringBoot项目用spring-data-redis的比较多,其实它主要是封装了jedis和lettuce两个客户端,相当于在它们基础上加了一层门面。
在java语言里redis官方最推荐的便是jedis、lettuce和redisson,如下图。

在这里插入图片描述

  • 在实际的项目开发中,对于一个需要对接Redis的项目来说,就面临着选择合适的Redis客户端。
  • 目前比较常用的Redis客户端有Redisson、Lettuce和Jedis,两者都有各自的优点和适用场景

2.Jedis介绍

在这里插入图片描述
Jedis的主要特点如下:

  • 简洁高效:Jedis的设计简洁高效,性能较好,可以通过直接发送命令字符串与Redis进行通信,适用于对Redis的原生命令操作更为关注的场景。
  • 社区活跃:Jedis是最早的Java Redis客户端,拥有庞大的用户社区和完善的文档支持,可以方便地获取到各种使用案例和问题解答。
  • 支持大部分特性:Jedis支持Redis的大部分特性,如事务、流水线、发布/订阅等,可以满足绝大多数的需求。

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

3.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提升了性能,丰富了功能,对于开发者来说就减少了自己造轮子。

4.Redisson介绍

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

  • 分布式对象:Redisson支持将Java对象存储在Redis中,以及在分布式环境中进行操作和调用。这使得开发人员可以更方便地使用常规的面向对象编程方式来处理分布式数据。
  • 分布式集合:Redisson提供了一系列分布式集合数据结构,比如Set、List、Queue、Deque、Map等。这些数据结构可以在分布式环境中进行操作和处理,使得开发人员能够更方便地实现分布式应用。
  • 分布式锁:Redisson提供了一种分布式锁的实现,支持公平锁和非公平锁两种模式。这使得开发人员可以更容易地实现分布式环境下的并发控制,避免数据竞争和资源争用。
  • 分布式调度器:Redisson提供了一种分布式调度器的实现,可以让开发人员在分布式环境中进行任务调度和定时任务的管理。这使得分布式应用的任务调度更加方便和灵活。
  • 集群支持:Redisson支持Redis的集群模式,可以轻松地在Redis集群中进行数据操作和处理。这使得Redisson能够处理大规模的数据量和高并发的请求。

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

Jedis 、Lettuce 、Redisson 横向对比

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

  • 30
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值