当前位置: 首页 > article >正文

Flowable工作流核心表结构全解析:从ACT_RE到ACT_HI,看完这篇就懂了

Flowable工作流引擎核心表结构深度解析从数据视角掌握流程运转机制1. 工作流引擎的数据架构设计哲学现代BPM系统的核心在于如何高效管理流程状态与历史轨迹Flowable通过精心设计的表结构实现了这一目标。与大多数开发者仅关注API调用不同深入理解底层数据模型才能真正掌握流程引擎的运作机理。Flowable的表命名遵循ACT_[模块]_[功能]的规范其中模块标识符尤为重要RERepository存储静态定义资源RURuntime处理运行时的动态数据HIHistory记录完整生命周期轨迹GEGeneral提供基础支撑服务这种分离设计带来三个显著优势运行时高效性RU表仅保留必要运行时数据保证操作性能历史完整性HI表提供完整的审计追踪能力资源隔离性RE表确保流程定义与实例解耦-- 典型流程实例的生命周期轨迹 SELECT * FROM ACT_HI_PROCINST WHERE BUSINESS_KEY_ PO-20230501;2. 流程定义阶段的核心表解析2.1 模型存储体系ACT_RE_*ACT_RE_MODEL表是流程设计的元数据中心但其实际内容存储在ACT_GE_BYTEARRAY中。这种分离存储的设计考虑了大型模型文件的处理效率字段说明示例值ID_模型UUIDc64059b7-a4d1-11ee-a7ee-3cf01158cd6cEDITOR_SOURCE_VALUE_ID_关联的BPMN XML存储ID62e51153-aad1-11ee-82ae-1063c84f60f7META_INFO_JSON格式的扩展属性{formType:10,formId:24}关键点版本控制通过REV_字段实现乐观锁DEPLOYMENT_ID_在发布前为NULL模型与部署是1:N关系2.2 部署过程的数据流转部署操作会触发以下数据变更ACT_RE_DEPLOYMENT记录部署事件ACT_GE_BYTEARRAY存储流程定义文件ACT_RE_PROCDEF生成可执行的流程定义// 典型部署代码示例 Deployment deployment repositoryService.createDeployment() .addClasspathResource(processes/leave.bpmn20.xml) .name(请假流程v1.2) .category(HR) .deploy();部署后各表关联关系ACT_RE_DEPLOYMENT └── ACT_RE_PROCDEF ├── ACT_GE_BYTEARRAY (BPMN文件) └── ACT_GE_BYTEARRAY (流程图PNG)3. 运行时表的关键设计原理3.1 执行实例与任务实例ACT_RU_EXECUTION和ACT_RU_TASK是运行时最重要的两个表执行实例表关键字段IS_ACTIVE_标识是否活动状态0/1ACT_ID_当前停留的节点IDPARENT_ID_支持子流程嵌套任务实例典型状态流转graph LR Created --|claim| Assigned Assigned --|complete| Finished Created --|timeout| Expired3.2 变量存储机制ACT_RU_VARIABLE采用多列存储不同类型变量变量类型存储列示例StringTEXT_审批意见LongLONG_1689293832000DoubleDOUBLE_3.1415926BinaryBYTEARRAY_ID_文件ID最佳实践-- 查询流程实例的所有变量 SELECT * FROM ACT_RU_VARIABLE WHERE PROC_INST_ID_ 133adae6-ae43-11ee-af7e-3cf01158cd6c;4. 历史表的归档策略与优化4.1 历史数据分级存储Flowable采用智能归档策略表名数据粒度保留策略ACT_HI_PROCINST流程实例长期保留ACT_HI_TASKINST任务实例可配置ACT_HI_DETAIL细粒度日志短期保留配置示例# 历史数据保存时长天 flowable.history-levelaudit flowable.history-cleanup-days304.2 历史查询优化技巧为常用查询添加索引CREATE INDEX idx_hi_procinst_buskey ON ACT_HI_PROCINST(BUSINESS_KEY_);使用历史服务API替代直接SQLhistoryService.createHistoricProcessInstanceQuery() .finishedAfter(startDate) .orderByProcessInstanceDuration().desc() .list();5. 实战中的表结构扩展方案5.1 业务关联设计建议的扩展表示例CREATE TABLE bpm_business_mapping ( id BIGINT PRIMARY KEY, proc_def_id VARCHAR(64) NOT NULL, business_type VARCHAR(50) NOT NULL, form_config JSON, UNIQUE KEY (proc_def_id, business_type) );5.2 性能监控表设计监控表示例结构字段类型描述metrics_timeDATETIME统计时间点running_instancesINT运行中实例数active_tasksINT待办任务总数avg_durationDECIMAL(10,2)平均处理时长监控查询示例-- 统计各流程的任务处理效率 SELECT p.KEY_, COUNT(*), AVG(TIMESTAMPDIFF(MINUTE, t.START_TIME_, t.END_TIME_)) FROM ACT_HI_TASKINST t JOIN ACT_RE_PROCDEF p ON t.PROC_DEF_ID_ p.ID_ GROUP BY p.KEY_;6. 深度调优与问题排查6.1 常见性能瓶颈识别RU表膨胀检查长时间运行的悬挂实例SELECT * FROM ACT_RU_EXECUTION WHERE IS_ACTIVE_1 AND START_TIME_ DATE_SUB(NOW(), INTERVAL 7 DAY);HI表过大验证历史清理策略是否生效-- 检查历史数据分布 SELECT DATE_FORMAT(START_TIME_, %Y-%m), COUNT(*) FROM ACT_HI_PROCINST GROUP BY DATE_FORMAT(START_TIME_, %Y-%m);6.2 锁竞争解决方案当出现并发冲突时优化事务粒度// 错误示例整个流程在单个事务中 // 正确做法分阶段提交 taskService.complete(taskId, variables);配置异步执行器flowable.async-executor-activatetrue flowable.async-executor-threads47. 与业务系统的集成模式7.1 数据关联方案对比方案优点缺点业务键关联松耦合需维护映射关系变量存储实现简单影响流程性能扩展表查询高效增加系统复杂度推荐做法// 启动流程时建立关联 runtimeService.startProcessInstanceByKey( leaveProcess, PO-20230501, // businessKey variables);7.2 人员适配器实现自定义人员解析示例public class CustomUserTaskListener implements TaskListener { Override public void notify(DelegateTask task) { String department (String) task.getVariable(applyDept); ListUser approvers hrService.findApprovers(department); task.addCandidateUsers(approvers.stream() .map(User::getUserId) .collect(Collectors.toList())); } }在实际项目中我们发现对ACT_RU_TASK和ACT_RU_IDENTITYLINK的联合查询是待办列表的性能关键点。通过为ASSIGNEE_和GROUP_ID_字段添加复合索引查询速度可提升5-8倍。同时建议定期归档已完成任务数据保持运行时表的精简。

相关文章:

Flowable工作流核心表结构全解析:从ACT_RE到ACT_HI,看完这篇就懂了

Flowable工作流引擎核心表结构深度解析:从数据视角掌握流程运转机制 1. 工作流引擎的数据架构设计哲学 现代BPM系统的核心在于如何高效管理流程状态与历史轨迹,Flowable通过精心设计的表结构实现了这一目标。与大多数开发者仅关注API调用不同&#xff0c…...

如何突破TIDAL平台限制,高效构建24-bit高解析度个人音乐库?

如何突破TIDAL平台限制,高效构建24-bit高解析度个人音乐库? 【免费下载链接】tidal-dl-ng TIDAL Media Downloader Next Generation! Up to HiRes / TIDAL MAX 24-bit, 192 kHz. 项目地址: https://gitcode.com/gh_mirrors/ti/tidal-dl-ng TIDAL …...

从手动保存到一键下载:抖音无水印视频获取的革命性工具

从手动保存到一键下载:抖音无水印视频获取的革命性工具 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback supp…...

STM32F4驱动ST7735S小屏幕:从SPI配置到图片显示,一个完整项目带你玩转TFTLCD

STM32F4驱动ST7735S小屏幕:从SPI配置到图片显示实战指南 手里这块1.44寸的ST7735S屏幕已经吃灰三个月了?跟着我做这个温湿度监测项目,保证让你的开发板和小屏幕都活起来。不需要死记硬背那些SPI参数,咱们直接动手做出能显示动态数…...

从音频采集到FPGA:手把手教你复刻一个8通道AD采样系统(附完整代码与PCB)

从音频采集到FPGA:手把手教你复刻一个8通道AD采样系统(附完整代码与PCB) 在嵌入式系统与信号处理领域,多通道数据采集一直是工程师面临的核心挑战之一。无论是工业自动化中的传感器网络,还是医疗设备中的生物电信号监测…...

手把手教你排查OpenWRT虚拟机网卡直通失败:从lspci到QEMU命令的避坑指南

手把手教你排查OpenWRT虚拟机网卡直通失败:从lspci到QEMU命令的避坑指南 虚拟化环境中实现网卡直通是许多网络爱好者和企业IT管理员追求的高性能解决方案。当你在Debian宿主机上尝试为OpenWRT虚拟机配置PCIe网卡直通时,可能会遇到各种意料之外的障碍——…...

别再乱码了!从ASCII到UTF-8,5分钟搞懂程序员必知的字符编码原理

别再乱码了!从ASCII到UTF-8,程序员必知的字符编码实战指南 当你从数据库导出CSV文件时,中文字符突然变成乱码;当API返回的JSON数据在控制台显示为"????";当同事发来的日志文件里夹杂着�符号—…...

深入聊聊Xilinx MIPI CSI-2 RX Subsystem IP:在Zynq UltraScale上解码OV5640视频的配置要点与性能调优

Xilinx MIPI CSI-2 RX Subsystem IP在Zynq UltraScale平台上的深度优化实践 OV5640摄像头作为工业视觉领域最常见的图像传感器之一,其MIPI接口的高带宽特性对FPGA设计提出了严苛要求。Xilinx提供的MIPI CSI-2 RX Subsystem IP虽然大幅降低了开发门槛,但…...

从硬件到代码:手把手拆解DMA外挂的完整链条(含Apex实战代码分析)

从硬件到代码:手把手拆解DMA外挂的完整链条(含Apex实战代码分析) 在游戏安全领域,DMA(直接内存访问)技术正逐渐成为高端作弊工具的核心组件。这种原本用于工业数据采集的技术,因其能够绕过CPU直…...

OpenClaw汉化版部署指南:本地AI助手从入门到精通

1. 项目概述 如果你是一个对AI智能体(AI Agent)技术感兴趣的开发者,或者你只是想在自己的电脑上部署一个能通过WhatsApp、Telegram等聊天软件和你对话的私人AI助手,那么你很可能已经听说过OpenClaw。这个在GitHub上收获了近20万星…...

2026数据科学学习路线图:从Python基础到深度学习部署实战

1. 数据科学学习路线图:一份面向2026年的实战指南 如果你正站在数据科学的大门前,看着里面琳琅满目的技术栈和层出不穷的新名词感到迷茫,不知道从哪里开始,也不知道该往哪里走,那么你来对地方了。这份路线图不是一份简…...

从图像压缩到推荐系统:特征值分解到底在哪些实际项目里悄悄干活?

从图像压缩到推荐系统:特征值分解到底在哪些实际项目里悄悄干活? 当你用手机拍下一张照片,系统瞬间完成高清压缩;当你在电商平台浏览商品,首页突然出现"猜你喜欢"的精准推荐;当你在搜索引擎输入关…...

3大核心功能解锁:用MATVT将电视遥控器变身精准鼠标控制器

3大核心功能解锁:用MATVT将电视遥控器变身精准鼠标控制器 【免费下载链接】matvt Virtual Mouse for Android TV that can be controlled via remote itself. 项目地址: https://gitcode.com/gh_mirrors/ma/matvt 您是否曾为Android TV上那些难以点击的小按钮…...

为什么83%的AI公司IPO被问询AISMM?2026奇点大会披露的3项硬指标已成交易所默认红线

更多请点击: https://intelliparadigm.com 第一章:2026奇点智能技术大会:AISMM与IPO准备 2026奇点智能技术大会(Singularity Intelligence Summit 2026)正式宣布启动AISMM(Autonomous Intelligent System …...

TFT Overlay:当云顶之弈的复杂性遇到开源社区的温暖

TFT Overlay:当云顶之弈的复杂性遇到开源社区的温暖 【免费下载链接】TFT-Overlay Overlay for Teamfight Tactics 项目地址: https://gitcode.com/gh_mirrors/tf/TFT-Overlay 在《英雄联盟:云顶之弈》的世界里,每个回合都是一次思维的…...

LuaDec51终极指南:快速掌握Lua 5.1字节码反编译的完整方法

LuaDec51终极指南:快速掌握Lua 5.1字节码反编译的完整方法 【免费下载链接】luadec51 Lua Decompiler for Lua version 5.1 项目地址: https://gitcode.com/gh_mirrors/lu/luadec51 你是否曾经面对一个加密的Lua字节码文件,却束手无策&#xff1f…...

百度网盘秒传脚本:永久有效的文件分享终极解决方案

百度网盘秒传脚本:永久有效的文件分享终极解决方案 【免费下载链接】rapid-upload-userscript-doc 秒传链接提取脚本 - 文档&教程 项目地址: https://gitcode.com/gh_mirrors/ra/rapid-upload-userscript-doc 你是否曾因百度网盘分享链接7天后失效而烦恼…...

老漏洞新谈:CVE-2010-0738的HEAD请求绕过与JBoss JMX Console的权限之殇

CVE-2010-0738:HEAD请求的艺术与JMX Console的防御盲区 十年前那个春寒料峭的三月,当安全研究员在JBoss JMX控制台前反复切换HTTP请求方法时,一个看似平常的HEAD请求意外触发了系统响应。这个后来被编号为CVE-2010-0738的漏洞,不…...

iOS原生AI助手开发实战:从UIKit选型到Stable Diffusion本地部署

1. 项目概述:一个原生、全能的iOS端AI助手最近在App Store上架了一款名为“Chat走啦”的iOS应用,它本质上是一个功能相当全面的ChatGPT原生客户端。和很多基于WebView简单套壳的应用不同,这个项目从底层网络请求到上层UI交互,都采…...

ChatGPT账号自动化创建:Selenium实战与反检测策略详解

1. 项目概述与核心价值最近在折腾一些AI应用开发,发现很多有意思的想法都卡在了一个看似简单、实则麻烦的环节上:获取一个可用的ChatGPT账号。无论是想测试最新的API功能,还是想搭建一个内部使用的对话机器人,账号都是绕不过去的门…...

Maven多模块项目实战:手把手教你配置pom.xml中的parent.relativePath,告别路径错误

Maven多模块项目实战:parent.relativePath配置全指南与深度解析 当你在深夜的办公室里,面对一个复杂的Maven多模块项目构建失败,控制台不断抛出"parent.relativePath points at wrong local POM"错误时,那种挫败感每个…...

别再只会ping了!用iperf3给你的CentOS 7服务器做个专业‘网络体检’

专业级网络性能诊断:用iperf3解锁CentOS服务器的隐藏问题 当服务器响应变慢、应用数据传输卡顿时,大多数运维人员的第一反应是执行ping测试。然而,这种基础手段只能告诉你网络是否连通,却无法揭示更深层次的性能瓶颈。真正的网络…...

5步让Windows字体拥有macOS般的清晰锐利:MacType终极配置指南

5步让Windows字体拥有macOS般的清晰锐利:MacType终极配置指南 【免费下载链接】mactype Better font rendering for Windows. 项目地址: https://gitcode.com/gh_mirrors/ma/mactype 还在为Windows系统下模糊的字体显示效果而烦恼吗?MacType作为一…...

保姆级教程:用MATLAB手把手仿真FMCW雷达测距测速(附77GHz毫米波雷达代码)

77GHz毫米波雷达实战:MATLAB实现FMCW测距测速全流程解析 第一次接触FMCW雷达仿真时,我被那些复杂的公式和理论推导搞得晕头转向——直到发现用MATLAB代码反向理解原理才是最高效的学习路径。本文将带你用不到200行代码,从零构建完整的77GHz毫…...

ARM-2D vs. LVGL/emWin:为你的Cortex-M项目选择GUI底层加速库的完整指南

ARM-2D与主流GUI框架深度整合实战指南 引言:嵌入式GUI加速的痛点与破局 在智能手表、工业HMI和家用电器等嵌入式场景中,流畅的图形界面已成为基础需求。但当我们为Cortex-M系列MCU设计GUI时,常陷入两难困境:要么使用LVGL、emWin等…...

避坑指南:ESP32用Modbus读485设备,为什么你的软串口总收不到数据?

ESP32 Modbus通信避坑指南:软串口数据丢失的深层分析与解决方案 当你在ESP32项目中使用Modbus协议通过485接口读取传感器数据时,是否遇到过这样的场景:硬件连接正确,代码看似无误,但软串口(SoftwareSerial)就是收不到任…...

别再只显示数字了!用TM1638+Arduino打造一个迷你桌面时钟/温湿度计(附完整代码)

用TM1638打造智能桌面时钟与温湿度监控系统 在电子DIY的世界里,总有一些小模块能以极低的成本带来巨大的乐趣。TM1638就是这样一款神奇的组合模块——它集成了8位数码管、8个LED指示灯和8个独立按键,价格却只要一杯奶茶的钱。今天,我们就用这…...

VisualCppRedist AIO终极指南:一站式解决Windows VC++运行库难题

VisualCppRedist AIO终极指南:一站式解决Windows VC运行库难题 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 你是否曾经遇到过Windows应用程序无法…...

Mac/Win双平台实测:彻底解决Scrcpy投屏的LIBUSB权限错误(2024最新)

Mac/Win双平台实战:2024年Scrcpy投屏LIBUSB权限错误的终极解法 当你在深夜赶工调试安卓应用,突然遭遇Scrcpy投屏闪退并弹出LIBUSB_ERROR_ACCESS错误时,那种烦躁感我深有体会。作为跨平台安卓开发的必备工具,Scrcpy在不同操作系统下…...

为OpenClaw构建现代化Web控制台:从架构设计到移动端访问

1. 项目概述:为OpenClaw打造一个现代化的本地Web控制台如果你和我一样,是个喜欢折腾本地AI和自动化工具的人,那你肯定对OpenClaw不陌生。它是一个功能强大的个人助理框架,能帮你处理文件、连接各种服务、甚至通过浏览器自动化来完…...