LiteFlow LiteFlow
💒首页
  • v2.13.2(当前版本)
  • What's New

    • 🌈What' s New In LiteFlow v2.13.2?
  • 历史版本

    • v2.12.X
    • v2.11.X
    • v2.10.X
    • v2.9.X
    • v2.8.X
  • 升级指南

    • 🌈2.13.0升级指南
    • 2.12.4升级指南
    • 2.12.0升级指南
    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
👑LF CLUB社区
  • 常见问题
  • 专题解释

    • 如何理解上下文这个概念?
    • Slot是一个什么样的概念,在框架中起到什么样的作用?
💖赞助
🧩插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
👥加入群聊
🧤谁在使用
  • Gitee (opens new window)
  • GitCode (opens new window)
  • Github (opens new window)

广告采用随机轮播方式显示 ❤️成为赞助商
💒首页
  • v2.13.2(当前版本)
  • What's New

    • 🌈What' s New In LiteFlow v2.13.2?
  • 历史版本

    • v2.12.X
    • v2.11.X
    • v2.10.X
    • v2.9.X
    • v2.8.X
  • 升级指南

    • 🌈2.13.0升级指南
    • 2.12.4升级指南
    • 2.12.0升级指南
    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
👑LF CLUB社区
  • 常见问题
  • 专题解释

    • 如何理解上下文这个概念?
    • Slot是一个什么样的概念,在框架中起到什么样的作用?
💖赞助
🧩插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
👥加入群聊
🧤谁在使用
  • Gitee (opens new window)
  • GitCode (opens new window)
  • Github (opens new window)
  • LiteFlow介绍
  • 项目特性
  • 安装和集成

  • 规则文件

  • 用代码动态构造规则

  • 使用详细指南

    • 开启和关闭
    • 同步异步编排
    • 执行器
    • 数据槽
      • Slot中的一些方法
      • Slot的数量
    • 普通组件
    • 条件组件
    • 脚本组件
    • 声明式组件
    • 前置后置组件
    • 组件标签
    • 子流程
    • 隐式子流程
    • 私有投递
    • 组件重试
    • 平滑热刷新
    • 组件切面
    • 异常处理机制
    • 步骤打印
    • 不同格式规则加载
    • When异步线程池
    • 自定义组件执行器
    • 简单监控
  • 示例工程

  • 性能表现
  • v2.6.X文档
  • 使用详细指南
铂赛东
2022-06-01
目录

数据槽

概念

在执行器执行流程时会分配唯一的一个数据槽给这个请求。不同请求的数据槽是完全隔离的。你可以理解为数据槽就是这个请求中的上下文,里面存放着此请求所有的数据。不同的组件之间是不传递参数的,所有的数据交互都是通过这个数据槽来实现的。

LiteFlow提供了一个默认的SLOT实现:DefaultSlot。这个默认的实现其实里面主要存储数据的容器就是一个Map。

比如可以通过getRequestData获得流程的初始参数,通过getChainName获取流程的命名,通过setInput,getInput,setOutput,getOutput设置和获取属于某个组件专有的数据对象。当然也提供了最通用的方法setData和getData用来设置和获取业务的数据。

建议

DefaultSlot虽然可以用,但是在实际业务中,用这个会存在大量的弱类型,存取数据的时候都要进行强转,颇为不方便。所以官方建议你自己去实现自己的Slot。

自己定义的Slot实质上就是一个最简单的值对象,只需继承AbsSlot就可以了。自己定义的Slot因为是强类型,更加贴合业务。

# Slot中的一些方法

无论你使用DefaultSlot还是自定义的Slot,Slot会有一些元方法供大家调用:

getRequestId():每一个链路在执行初期都会生成这个链路的唯一ID,同时这个ID也会打印在日志中。方便于追踪。这个方法能得到这个链路追踪ID。

getRequestData():获取链路的初始参数。

getChainName():获取链路的名称。

getException():得到链路中的异常信息,如果没有就为null。

getExecuteStepStr():得到链路中的执行步骤信息。

setData(K,V):往slot中设置一个值。

getData(K):从Slot里得到一个值。

# Slot的数量

在LiteFlow的配置中,提供一个slotSize的参数可以去配置初始化数量,但是这个默认值就是1024,在2.6.0版本中,当slot容量不够时,会按照0.75的因子去进行自动扩容。所以这个值不推荐主动配置。除非有特殊情况。

帮助我们改善此文档 (opens new window)
上次更新: 2022/10/07, 00:22:18
执行器
普通组件

← 执行器 普通组件→

Theme by Vdoing | Copyright © 2020-2025 铂赛东 | MIT License
沪ICP备18012955号-2
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式