详细学习一下 Redisson 的 `RFuture`

一篇从 源码到实战 的完整笔记 版本:Redisson 3.23.4 + JDK 17


目录

  1. 前言

  2. RFuture 是什么

  3. 类图与继承体系

  4. 生命周期 & 状态流转

  5. 四种典型用法

    1. 同步阻塞 get()
    2. 异步回调 whenComplete()
    3. 链式组合 thenCompose()
    4. 批量等待 CompletableFuture.allOf()
  6. 与 JDK Future 的差异

  7. 线程模型与调度器

  8. 常见陷阱 & 最佳实践

  9. 性能调优

  10. 总结


前言

在 Redisson 里,所有异步 APIRBucketAsync, RLockAsync, RMapAsync...) 都返回 RFuture<T>。 理解它 = 理解 Redisson 异步编程的全部乐趣。


RFuture 是什么

表格

复制

维度 描述
定义 public interface RFuture<V> extends CompletionStage<V>, Future<V>
作用 统一异步结果容器,屏蔽 Netty 与 JDK Future 差异
实现 RedissonPromise (内部继承 Netty DefaultPromise

类图与继承体系


生命周期 & 状态流转

表格

复制

状态 含义
UNSUCCESS 未完成
SUCCESS 正常完成
FAILURE 异常完成

java

复制

arduino 复制代码
enum PromiseState { UNSUCCESS, SUCCESS, FAILURE }

四种典型用法

1. 同步阻塞 get()

java

复制

ini 复制代码
RFuture<String> f = bucket.getAsync();
String value = f.get(3, TimeUnit.SECONDS);

2. 异步回调 whenComplete

java

复制

lua 复制代码
f.whenComplete((r, e) -> {
    if (e == null) {
        log.info("value: {}", r);
    } else {
        log.error("error", e);
    }
});

3. 链式组合 thenCompose

java

复制

less 复制代码
bucket.setAsync("A")
      .thenCompose(v -> bucket.getAsync())
      .thenAccept(System.out::println);

4. 批量等待

java

复制

vbscript 复制代码
List<RFuture<?>> batch = List.of(
        bucket.setAsync("a"),
        map.putAsync("k", "v")
);
CompletableFuture.allOf(batch.toArray(new CompletableFuture[0])).join();

与 JDK Future 的差异

表格

复制

特性 RFuture JDK Future
回调注册 addListener()
链式 API thenCompose()
超时 await(timeout)
取消 cancel(true)
异常携带 cause() get() 抛出

线程模型与调度器

  • 内部线程 :Redisson 的 ExecutorService(默认 ForkJoinPool.commonPool()
  • 回调线程:Netty EventLoop 或业务线程
  • 线程切换thenRunAsync(executor) 显式指定

常见陷阱 & 最佳实践

表格

复制

陷阱 解决
回调阻塞 耗时任务转业务线程
内存泄漏 ByteBuf 需要 release()
死循环 避免在回调里再次同步等待

性能调优

表格

复制

配置 建议
线程池 redisson.executor = customExecutor
连接池 redisson.nettyThreads = 0
超时 RFuture.get(timeout)

总结

  • RFuture = Netty Promise + JDK CompletionStage
  • 三步走:注册 → 完成 → 回调
  • 一句话 :掌握 RFuture,就掌握了 Redisson 异步世界的钥匙!
相关推荐
Smoothzjc18 小时前
👉 求你了,别再裸写 fetch 做 AI 流式响应了!90% 的人都在踩这个坑
前端·人工智能·后端
superman超哥19 小时前
Rust 或模式(Or Patterns)的语法:多重匹配的优雅表达
开发语言·后端·rust·编程语言·rust或模式·or patterns·多重匹配
摸鱼的春哥20 小时前
实战:在 Docker (Windows) 中构建集成 yt-dlp 的“满血版” n8n 自动化工作流
前端·javascript·后端
IT 行者20 小时前
Spring Security 7 OAuth2 Token 格式选择浅析
java·后端·spring
幽络源小助理20 小时前
Springboot机场乘客服务系统源码 – SpringBoot+Vue项目免费下载 | 幽络源
vue.js·spring boot·后端
源代码•宸20 小时前
Golang基础语法(go语言error、go语言defer、go语言异常捕获、依赖管理、Go Modules命令)
开发语言·数据库·后端·算法·golang·defer·recover
SnrtIevg20 小时前
Vavr 用户指南
java·后端
PieroPC20 小时前
用FastAPI 一个 后端 和 两个前端 原生HTML/CSS/JS 、Vue3 写一个博客系统 例
前端·后端
Way2top20 小时前
Go语言动手写Web框架 - Gee第五天 中间件
后端·go