【018】Dubbo3从0到1系列之时间轮流程图解

文章目录

  • Dubbo3时间轮
      • [7.2.8 HashedWheelTimer图解](#7.2.8 HashedWheelTimer图解)
        • [✅ 1. 架构图](#✅ 1. 架构图)
        • [✅ 2. 初始化流程图](#✅ 2. 初始化流程图)
        • [✅ 3. 添加定时任务流程图](#✅ 3. 添加定时任务流程图)
        • [✅ 4. Worker 线程处理流程图](#✅ 4. Worker 线程处理流程图)
        • [✅ 5. 任务转移流程图](#✅ 5. 任务转移流程图)
        • [✅ 6. 任务到期处理流程](#✅ 6. 任务到期处理流程)
        • [✅ 7. 时间轮工作时序图](#✅ 7. 时间轮工作时序图)
        • [✅ 8. 任务取消时序图](#✅ 8. 任务取消时序图)
      • [7.2.9 举例说明](#7.2.9 举例说明)

Dubbo3时间轮

7.2.8 HashedWheelTimer图解

✅ 1. 架构图
✅ 2. 初始化流程图
✅ 3. 添加定时任务流程图
✅ 4. Worker 线程处理流程图
✅ 5. 任务转移流程图
✅ 6. 任务到期处理流程
✅ 7. 时间轮工作时序图

Application HashedWheelTimer Worker Thread HashedWheelBucket newTimeout(task, delay, unit) 创建 HashedWheelTimeout 加入 timeouts 队列 返回 Timeout start() 启动 Worker 线程 waitForNextTick() processCancelledTasks() 处理 cancelledTimeouts 队列 transferTimeoutsToBuckets() 从 timeouts 队列取出任务 根据 deadline 计算并添加到对应桶 expireTimeouts() 遍历桶内任务 处理到期任务 (remainingRounds<=0) 执行 TimerTask.run() 更新未到期任务 (remainingRounds--) loop [每个 tick 周期] Application HashedWheelTimer Worker Thread HashedWheelBucket

✅ 8. 任务取消时序图

Application HashedWheelTimer HashedWheelTimeout Worker Thread timeout.cancel() CAS 设置状态为 ST_CANCELLED 加入 cancelledTimeouts 队列 返回 true processCancelledTasks() 从 cancelledTimeouts 取出任务 timeout.remove() 从桶中移除自己 减少 pendingTimeouts 计数 Application HashedWheelTimer HashedWheelTimeout Worker Thread

这些图表展示了 HashedWheelTimer 的核心工作机制,包括初始化过程、任务添加、任务处理以及任务取消等关键环节。整体设计采用了生产者-消费者模式,通过队列解耦了任务提交和任务处理的过程,并利用时间轮算法优化了大量定时任务的管理效率。

7.2.9 举例说明

  1. 用户提交一个延迟为 T = 300 秒(5 分钟) 的任务;
  2. 计算总 tick 数:totalTicks = T / tickDuration = 300_000ms / 100ms = 3000 ticks. (时间轮的指针,是一个步长为 1 的单调递增计数器)
  3. 由于 wheel 只有 512 个槽,计算:
    • remainingRounds = totalTicks / ticksPerWheel = 3000 / 512 ≈ 5 轮
      • remainingRounds ,剩余的轮数
    • stopIndex = (currentTick + totalTicks) % ticksPerWheel
      • 某个槽位停止下来
  4. 将任务封装为 HashedWheelTimeout,记录ticksPerWheel
  5. 时间轮工作线程每 tick 一次:
    • 当指针到达 stopIndex 时,检查该槽位所有任务;
    • 若 remainingRounds > 0,则 remainingRounds--不执行任务,继续等待下一轮;
    • 直到 remainingRounds == 0,才真正执行任务。

✅ 这就是 "多轮计数"机制,无需多级时间轮,也能支持任意长时间任务。

🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉

  • Enjoy it

🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉

相关推荐
三水不滴9 小时前
有 HTTP 了为什么还要有 RPC?
经验分享·笔记·网络协议·计算机网络·http·rpc
岁岁种桃花儿14 小时前
注册中心宕机后,RPC调用还能成功吗?主流框架实测级分析
zookeeper·eureka·rpc
顾北122 天前
MCP服务端开发:图片搜索助力旅游计划
java·spring boot·dubbo
珹洺3 天前
Bootstrap-HTML(二)深入探索容器,网格系统和排版
前端·css·bootstrap·html·dubbo
devmoon4 天前
快速了解兼容 Ethereum 的 JSON-RPC 接口
开发语言·网络·rpc·json·区块链·智能合约·polkadot
南墙上的石头4 天前
docker日常使用命令汇总
docker·容器·rpc
量子炒饭大师6 天前
【C++入门】—— 【什么时候需要用到深拷贝】C++的类中何时需要用到深拷贝?保姆级别带你罗列所有可能!
java·c++·dubbo·深拷贝
柱子jason7 天前
基于IOT-Tree Server支持的gRPC服务,使用C#开发自己的设备监控客户端
物联网·rpc·c#·自动化·iiot·iot-tree
橘颂TA7 天前
【测试】自动化测试函数介绍——web 测试
python·功能测试·selenium·测试工具·dubbo
wc888 天前
dubbo本地直连一个程序既当提供者又当消费者问题
dubbo