Jedis那么低性能,还在用?赶紧换上 lettuce 吧

文章对比了Redis的三大Java客户端Jedis、Redisson和Lettuce,详细分析了它们的优缺点。Jedis全面支持Redis命令但不支持异步,Redisson提供分布式数据结构和服务,而Lettuce是线程安全且支持同步异步的高级客户端。根据需求,推荐在SpringBoot2后默认的lettuce基础上结合Redisson使用,以利用其分布式特性和高性能。

3大redis客户端:Jedis、Redisson、Lettuce ,如何选型?

简介:Redis 的3大 Java 客户端组件

Redis 官方推荐的 Java 客户端有Jedis、lettuce 和 Redisson。

客户端1:Jedis

是老牌的Redis的Java实现客户端,提供了比较全面的Redis命令的支持

Jedis 在线网址:

http://tool.oschina.net/uploads/apidocs/redis/clients/jedis/Jedis.html

客户端2:Redisson

实现了分布式和可扩展的Java数据结构。促使使用者对Redis的关注分离,提供很多分布式相关操作服务,例如,分布式锁,分布式集合,可通过Redis支持延迟队列

redisson 官网地址:

https://redisson.org/

redisson git项目地址:

https://github.com/redisson/redisson

客户端3:lettuce

高级Redis客户端,用于线程安全同步,异步和响应使用,支持集群,Sentinel,管道和编码器。

基于Netty框架的事件驱动的通信层,其方法调用是异步的。Lettuce的API是线程安全的,所以可以操作单个Lettuce连接来完成各种操作

lettuce 官网地址:

https://lettuce.io/

lettuce git项目地址:

https://github.com/lettuce-io/lettuce-core

客户端组件1:Jedis

Jedis 是老牌的 Redis 的 Java 实现客户端,提供了比较全面的 Redis 命令的支持

优点:

  • 支持全面的 Redis 操作特性(可以理解为API比较全面)。

缺点:

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

客户端组件2: Redisson

Redisson 是一个在 Redis 的基础上实现的 Java 驻内存数据网格(In-Memory Data Grid)。

Redisson 提供了使用Redis 的最简单和最便捷的方法。

它不仅提供了一系列的分布式的 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的关注分离(Separation of Concern),从而让使用者能够将精力更集中地放在处理业务逻辑上。

优点:

  • 使用者对 Redis 的关注分离,可以类比 Spring 框架,这些框架搭建了应用程序的基础框架和功能,提升开发效率,让开发者有更多的时间来关注业务逻辑;
  • 提供很多分布式相关操作服务,例如,分布式锁,分布式集合,可通过Redis支持延迟队列等。
  • Redisson基于Netty框架的事件驱动的通信层,其方法调用是异步的。
  • Redisson的API是线程安全的,所以可以操作单个Redisson连接来完成各种操作

缺点:

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

客户端组件3: lettuce

lettuce ([ˈletɪs]),是一种可扩展的线程安全的 Redis 客户端,支持异步模式。

如果避免阻塞和事务操作,如BLPOP和MULTI/EXEC,多个线程就可以共享一个连接。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值