mirror of
https://github.com/aceld/kis-flow.git
synced 2025-01-23 07:30:23 +08:00
add Action module
This commit is contained in:
parent
c066ebae48
commit
f330c94f4c
@ -54,3 +54,7 @@ const (
|
||||
TIDB KisConnType = "tidb"
|
||||
ES KisConnType = "es"
|
||||
)
|
||||
|
||||
const (
|
||||
ActionNoJump = "NoJump"
|
||||
)
|
||||
|
@ -37,6 +37,8 @@ type KisFlow struct {
|
||||
buffer common.KisRowArr // 用来临时存放输入字节数据的内部Buf, 一条数据为interface{}, 多条数据为[]interface{} 也就是KisBatch
|
||||
data common.KisDataMap // 流式计算各个层级的数据源
|
||||
inPut common.KisRowArr // 当前Function的计算输入数据
|
||||
abort bool // 是否中断Flow
|
||||
action kis.Action // 当前Flow所携带的Action动作
|
||||
}
|
||||
|
||||
// NewKisFlow 创建一个KisFlow.
|
||||
@ -149,6 +151,7 @@ func (flow *KisFlow) Run(ctx context.Context) error {
|
||||
var fn kis.Function
|
||||
|
||||
fn = flow.FlowHead
|
||||
flow.abort = false
|
||||
|
||||
if flow.Conf.Status == int(common.FlowDisable) {
|
||||
//flow被配置关闭
|
||||
@ -164,7 +167,7 @@ func (flow *KisFlow) Run(ctx context.Context) error {
|
||||
}
|
||||
|
||||
//流式链式调用
|
||||
for fn != nil {
|
||||
for fn != nil && flow.abort == false {
|
||||
|
||||
// flow记录当前执行到的Function 标记
|
||||
fid := fn.GetId()
|
||||
@ -184,21 +187,25 @@ func (flow *KisFlow) Run(ctx context.Context) error {
|
||||
return err
|
||||
} else {
|
||||
//Success
|
||||
|
||||
if err := flow.commitCurData(ctx); err != nil {
|
||||
fn, err = flow.dealAction(ctx, fn)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// 更新上一层FuncitonId游标
|
||||
flow.PrevFunctionId = flow.ThisFunctionId
|
||||
|
||||
fn = fn.Next()
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
// Next 当前Flow执行到的Function进入下一层Function所携带的Action动作
|
||||
func (flow *KisFlow) Next(acts ...kis.ActionFunc) error {
|
||||
|
||||
// 加载Function FaaS 传递的 Action动作
|
||||
flow.action = kis.LoadActions(acts)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (flow *KisFlow) GetName() string {
|
||||
return flow.Name
|
||||
}
|
||||
|
@ -62,26 +62,63 @@ func (flow *KisFlow) getCurData() (common.KisRowArr, error) {
|
||||
return flow.data[flow.PrevFunctionId], nil
|
||||
}
|
||||
|
||||
// commitReuseData
|
||||
func (flow *KisFlow) commitReuseData(ctx context.Context) error {
|
||||
|
||||
// 判断上层是否有结果数据, 如果没有则退出本次Flow Run循环
|
||||
if len(flow.data[flow.PrevFunctionId]) == 0 {
|
||||
flow.abort = true
|
||||
return nil
|
||||
}
|
||||
|
||||
// 本层结果数据等于上层结果数据(复用上层结果数据到本层)
|
||||
flow.data[flow.ThisFunctionId] = flow.data[flow.PrevFunctionId]
|
||||
|
||||
// 清空缓冲Buf (如果是ReuseData选项,那么提交的全部数据,都将不会携带到下一层)
|
||||
flow.buffer = flow.buffer[0:0]
|
||||
|
||||
log.Logger().DebugFX(ctx, " ====> After commitReuseData, flow_name = %s, flow_id = %s\nAll Level Data =\n %+v\n", flow.Name, flow.Id, flow.data)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (flow *KisFlow) commitVoidData(ctx context.Context) error {
|
||||
if len(flow.buffer) != 0 {
|
||||
return nil
|
||||
}
|
||||
|
||||
// 制作空数据
|
||||
batch := make(common.KisRowArr, 0)
|
||||
|
||||
// 将本层计算的缓冲数据提交到本层结果数据中
|
||||
flow.data[flow.ThisFunctionId] = batch
|
||||
|
||||
log.Logger().DebugFX(ctx, " ====> After commitVoidData, flow_name = %s, flow_id = %s\nAll Level Data =\n %+v\n", flow.Name, flow.Id, flow.data)
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
//commitCurData 提交Flow当前执行Function的结果数据
|
||||
func (flow *KisFlow) commitCurData(ctx context.Context) error {
|
||||
|
||||
//判断本层计算是否有结果数据,如果没有则退出本次Flow Run循环
|
||||
// 判断本层计算是否有结果数据,如果没有则退出本次Flow Run循环
|
||||
if len(flow.buffer) == 0 {
|
||||
flow.abort = true
|
||||
return nil
|
||||
}
|
||||
|
||||
// 制作批量数据batch
|
||||
batch := make(common.KisRowArr, 0, len(flow.buffer))
|
||||
|
||||
//如果strBuf为空,则没有添加任何数据
|
||||
// 如果strBuf为空,则没有添加任何数据
|
||||
for _, row := range flow.buffer {
|
||||
batch = append(batch, row)
|
||||
}
|
||||
|
||||
//将本层计算的缓冲数据提交到本层结果数据中
|
||||
// 将本层计算的缓冲数据提交到本层结果数据中
|
||||
flow.data[flow.ThisFunctionId] = batch
|
||||
|
||||
//清空缓冲Buf
|
||||
// 清空缓冲Buf
|
||||
flow.buffer = flow.buffer[0:0]
|
||||
|
||||
log.Logger().DebugFX(ctx, " ====> After commitCurData, flow_name = %s, flow_id = %s\nAll Level Data =\n %+v\n", flow.Name, flow.Id, flow.data)
|
||||
@ -89,7 +126,7 @@ func (flow *KisFlow) commitCurData(ctx context.Context) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
//ClearData 清空flow所有数据
|
||||
// clearData 清空flow所有数据
|
||||
func (flow *KisFlow) clearData(data common.KisDataMap) {
|
||||
for k := range data {
|
||||
delete(data, k)
|
||||
|
@ -29,4 +29,6 @@ type Flow interface {
|
||||
GetConfig() *config.KisFlowConfig
|
||||
// GetFuncConfigByName 得到当前Flow的配置
|
||||
GetFuncConfigByName(funcName string) *config.KisFuncConfig
|
||||
// Next 当前Flow执行到的Function进入下一层Function所携带的Action动作
|
||||
Next(acts ...ActionFunc) error
|
||||
}
|
||||
|
@ -62,7 +62,7 @@ func (pool *kisPool) AddFlow(name string, flow Flow) {
|
||||
panic(errString)
|
||||
}
|
||||
|
||||
log.Logger().InfoF("Add FlowRouter FlowName=%s\n", name)
|
||||
log.Logger().InfoF("Add FlowRouter FlowName=%s", name)
|
||||
}
|
||||
|
||||
func (pool *kisPool) GetFlow(name string) Flow {
|
||||
|
Loading…
Reference in New Issue
Block a user