数据槽
概念
在执行器执行流程时会分配唯一的一个数据槽给这个请求。不同请求的数据槽是完全隔离的。你可以理解为数据槽就是这个请求中的上下文,里面存放着此请求所有的数据。不同的组件之间是不传递参数的,所有的数据交互都是通过这个数据槽来实现的。
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的因子去进行自动扩容。所以这个值不推荐主动配置。除非有特殊情况。