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

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

    • v2.9.X
    • v2.8.X
    • v2.7.X
    • v2.6.X
  • 升级指南

    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
❓问答
💖赞助
🧩插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
加入群聊
用户
  • TLog-轻量级的分布式日志追踪神器 (opens new window)
  • ERD ONLINE-开箱即用的数据库建模、产品版本管理软件 (opens new window)
  • Forest-更轻量、更简单实用的HTTP客户端框架 (opens new window)
Gitee (opens new window)
Github (opens new window)
  • 简体中文 (opens new window)
  • English (opens new window)
💒首页
  • v2.10.0(当前版本)
  • What's New

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

    • v2.9.X
    • v2.8.X
    • v2.7.X
    • v2.6.X
  • 升级指南

    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
❓问答
💖赞助
🧩插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
加入群聊
用户
  • TLog-轻量级的分布式日志追踪神器 (opens new window)
  • ERD ONLINE-开箱即用的数据库建模、产品版本管理软件 (opens new window)
  • Forest-更轻量、更简单实用的HTTP客户端框架 (opens new window)
Gitee (opens new window)
Github (opens new window)
  • 简体中文 (opens new window)
  • English (opens new window)
  • 🍤LiteFlow简介
  • 🍓项目特性
  • 🍟快速开始(Hello world)

    • 🍄说明
    • 🌿Springboot场景安装运行

      • 🧬依赖
      • ⚙️配置
      • 🛫执行
    • 🌱Spring场景安装运行

      • 🧬依赖
      • ⚙️配置
      • 🛫执行
    • 🌵其他场景安装运行

      • 🍄说明
      • 🧬依赖
      • ⚙️配置
      • 🛫执行
  • 🍢配置项

    • 🍄说明
    • 🌿Springboot下的配置项
    • 🌱Spring下的配置项
    • 🌵其他场景代码设置配置项
  • 🗂规则文件

    • 📔规则文件格式
      • 规则组成部分
    • 📕本地规则文件配置
    • 📗ZK规则文件配置源
    • 📘SQL数据库配置源
    • 📋Nacos配置源
    • 🗄Etcd配置源
    • 📜Apollo配置源
    • 📙自定义配置源
  • 🔗常规组件

    • 📎普通组件
    • ✂️选择组件
    • 📌条件组件
    • 🧬次数循环组件
    • ⛓条件循环组件
    • ⌛️迭代循环组件
    • 🧿退出循环组件
  • 🧩EL规则的写法

    • 🍄说明
    • 🌴串行编排
    • 🎋并行编排
    • 🌾选择编排
    • 🌵条件编排
    • 🌳循环编排
    • 🎃捕获异常表达式
    • 🍁使用子流程
    • 🍂使用子变量
    • 💐复杂编排例子
    • 🌻关于分号
    • 🌰关于注释
    • 🐚组件名包装
    • 🔆验证规则
  • 🌮数据上下文

    • 🍄说明
    • 🌯数据上下文的定义和使用
    • 🪶用初始化好的上下文传入
  • 🛩执行器

    • 🍄说明
    • 🎡执行方法
    • 🎢流程入参
    • 🎈LiteflowResponse对象
  • 🍋脚本组件

    • 🍫选择脚本语言
    • 🍕定义脚本组件
    • 🍱多脚本语言混合共存
    • 🌯文件脚本的定义
    • 🍣与Java进行交互
    • 🍘动态刷新脚本
  • 🍇声明式组件

    • 🥭什么叫声明式组件
    • 🧅类级别式声明
    • 🥥方法级别式声明
  • 🎲用代码动态构造规则

    • 🍄说明
    • 🎯如何构造
  • 🎨高级特性

    • 🍒前置和后置组件
    • 🍌本地规则文件监听
    • 🥠替补组件
    • 🍉组件参数
    • 🍑组件别名
    • 🍍组件标签
    • 🥝组件事件回调
    • 🥑隐式子流程
    • 🍕私有投递
    • 🍣组件重试
    • 🍖平滑热刷新
    • 🍪组件切面
    • 🍡步骤信息
    • 🧊异常
    • 🧇打印信息详解
    • 🧁自定义请求Id
    • 🌭不同格式规则加载
    • 🥗异步线程池自定义
    • 🍿自定义组件执行器
    • 🍥简单监控
    • 🧉XML的DTD
  • ⛱测试用例以及示例

    • 🪁测试用例
    • 🪀DEMO案例
  • 🪂性能表现
  • v2.10.X文档
  • 🗂规则文件
铂赛东
2022-06-04
目录

📔规则文件格式

LiteFlow支持3种配置方式

  • xml
  • json
  • yml

json,yml,xml配置起来都差不多,不会增加你额外的学习负担。只是形式不同而已。

提示

在后面的章节中,示例基本都是以xml配置来进行,如要换成json和yml,则自行参考这章给出的配置范本。

# 规则组成部分

LiteFlow的规则文件非常轻量,非常容易上手。主要由Node节点和Chain节点组成。

提示

必须要说明的是,Node节点在Springboot/Spring环境体系中是非必须的,只要将相应的组件注册到上下文中即可。当然如果配置在规则文件中,框架也会将节点注册到Spring上下文中。

在非Spring环境体系中,Node节点是必须的。如果不配置Node,系统会报找不到节点的错误。这点要务必注意下。

以下的格式是只作为一个范本,提供给使用者参考。

    XML在三种模式下的配置示例

    在xml形式下的rule-source的配置方式如下:

    本地文件:liteflow.rule-source=config/flow.el.xml

    自定义配置源:liteflow.rule-source=el_xml:com.yomahub.liteflow.test.TestCustomParser

    <?xml version="1.0" encoding="UTF-8"?>
    <flow>
        <nodes>
            <node id="a" class="com.yomahub.liteflow.test.parser.cmp.ACmp"/>
            <node id="b" class="com.yomahub.liteflow.test.parser.cmp.BCmp"/>
            <node id="c" class="com.yomahub.liteflow.test.parser.cmp.CCmp"/>
            <node id="d" class="com.yomahub.liteflow.test.parser.cmp.DCmp"/>
        </nodes>
    
        <chain name="chain1">
            THEN(
                a, b, WHEN(c,d)
            );
        </chain>
    </flow>
    

    JSON在三种模式下的配置示例

    在json形式下的rule-source的配置方式如下:

    本地文件:liteflow.rule-source=config/flow.el.json

    自定义配置源:liteflow.rule-source=el_json:com.yomahub.liteflow.test.TestCustomParser

    {
      "flow": {
        "nodes": {
          "node": [
            {
              "id": "a",
              "class": "com.yomahub.liteflow.test.parser.cmp.ACmp"
            },
            {
              "id": "b",
              "class": "com.yomahub.liteflow.test.parser.cmp.BCmp"
            },
            {
              "id": "c",
              "class": "com.yomahub.liteflow.test.parser.cmp.CCmp"
            },
            {
              "id": "d",
              "class": "com.yomahub.liteflow.test.parser.cmp.DCmp"
            }
          ]
        },
        "chain": [
          {
            "name": "chain1",
            "value": "THEN(a, b, WHEN(c, d))"
          }
        ]
      }
    }
    

    YAML在三种模式下的配置示例

    在yaml形式下的rule-source的配置方式如下:

    本地文件:liteflow.rule-source=config/flow.el.yml

    自定义配置源:liteflow.rule-source=el_yml:com.yomahub.liteflow.test.TestCustomParser

    flow:
      nodes:
        node:
          - id: a
            class: com.yomahub.liteflow.test.parser.cmp.ACmp
          - id: b
            class: com.yomahub.liteflow.test.parser.cmp.BCmp
          - id: c
            class: com.yomahub.liteflow.test.parser.cmp.CCmp
          - id: d
            class: com.yomahub.liteflow.test.parser.cmp.DCmp
      chain:
        - name: chain1
          value: "THEN(a, b, WHEN(c, d))"
    
    // Make sure to add code blocks to your code group
    帮助我们改善此文档 (opens new window)
    上次更新: 2023/03/17, 01:44:42
    🌵其他场景代码设置配置项
    📕本地规则文件配置

    ← 🌵其他场景代码设置配置项 📕本地规则文件配置→

    Theme by Vdoing | Copyright © 2020-2023 铂赛东 | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式