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

Camunda并行会签实战:从BPMN设计到数据库状态变化的完整追踪

Camunda并行会签实战从BPMN设计到数据库状态变化的完整追踪在复杂业务流程自动化领域并行会签是一种常见但实现难度较高的模式。当三个部门主管需要同时审批一份采购申请时传统串行审批会导致效率低下而并行处理又面临状态同步的挑战。Camunda作为业界领先的开源流程引擎其多实例任务特性为这类场景提供了优雅解决方案。本文将带您深入Camunda引擎内部通过直接观察数据库表变化揭示并行会签的完整生命周期。不同于常规教程仅展示界面操作我们将聚焦ACT_RU_TASK、ACT_RU_EXECUTION等核心表的实时变化用数据库视角还原并行分支创建、任务完成、实例汇聚的全过程。这种数据库探针式分析方法特别适合需要深度排查流程异常或优化性能的进阶开发者。1. 并行会签的BPMN建模要点实现有效并行会签的第一步是正确建模。在Camunda Modeler中创建包含多实例标记的用户任务时关键要掌握三个配置维度集合型多实例配置参数参数名必填作用示例值collection是参与者集合变量名assigneeListelementVariable是集合元素变量名assigneecompletionCondition否提前完成条件${nrOfCompletedInstances/nrOfInstances 0.5}典型的Groovy脚本初始化示例def approvers [finance_mgr, tech_mgr, ops_mgr] execution.setVariable(approverList, approvers)注意集合变量必须在流程实例启动前初始化否则会抛出NullValueException。推荐在启动事件或第一个任务配置执行监听器。2. 运行时表结构深度解析当流程实例运行到并行会签环节时Camunda会在底层创建复杂的执行树结构。通过以下SQL可观察运行时状态核心运行时表字段说明-- 查看任务实例状态 SELECT ID_, NAME_, ASSIGNEE_, SUSPENSION_STATE_, CASE SUSPENSION_STATE_ WHEN 1 THEN Active WHEN 2 THEN Suspended END AS STATE_DESC FROM ACT_RU_TASK WHERE PROC_INST_ID_ 流程实例ID; -- 查看执行流状态 SELECT ID_, ACT_ID_, IS_ACTIVE_, IS_SCOPE_, IS_CONCURRENT_, SEQUENCE_COUNTER_ FROM ACT_RU_EXECUTION WHERE PROC_INST_ID_ 流程实例ID;当三个并行任务创建时您会观察到ACT_RU_TASK表插入三条记录ASSIGNEE_分别对应集合元素ACT_RU_EXECUTION表生成四条记录1条父执行流IS_SCOPE_13条子执行流IS_CONCURRENT_13. 任务完成时的状态迁移追踪每个会签任务完成时数据库会发生连锁反应。以下实验演示user1完成审批时的变化步骤1查询初始状态-- 记录当前任务和执行流ID SELECT ID_ FROM ACT_RU_TASK WHERE ASSIGNEE_ user1; SELECT ID_ FROM ACT_RU_EXECUTION WHERE ACT_ID_ parallel_approval;步骤2完成任务后检查-- 原任务消失 SELECT * FROM ACT_RU_TASK WHERE ID_ 原任务ID; -- 历史表新增记录 SELECT ACT_ID_, ACT_NAME_, ASSIGNEE_, END_TIME_ FROM ACT_HI_ACTINST WHERE PROC_INST_ID_ 流程实例ID ORDER BY START_TIME_ DESC LIMIT 1; -- 执行流计数器变化 SELECT SEQUENCE_COUNTER_ FROM ACT_RU_EXECUTION WHERE ID_ 父执行流ID;典型现象包括ACT_RU_TASK中对应记录删除ACT_HI_ACTINST新增完成记录父执行流的SEQUENCE_COUNTER_值递增4. 汇聚网关的数据库表现当最后一个并行任务完成时引擎触发隐式汇聚。此时可观察到汇聚时的关键变化所有子执行流被删除父执行流的IS_ACTIVE_变为0历史表中生成完整的并行分支记录流程变量同步到父作用域验证SQL-- 检查执行流状态 SELECT ID_, IS_ACTIVE_, ACT_ID_ FROM ACT_RU_EXECUTION WHERE PROC_INST_ID_ 流程实例ID; -- 检查历史活动 SELECT ACT_ID_, ACT_INST_STATE_ FROM ACT_HI_ACTINST WHERE PROC_INST_ID_ 流程实例ID AND ACT_TYPE_ multiInstanceBody;5. 异常场景排查指南当并行会签出现异常时建议按此顺序排查集合变量未初始化检查ACT_RU_VARIABLE表是否存在预期变量验证Groovy脚本是否在正确节点执行任务卡在创建阶段确认ACT_RU_TASK有无预期记录检查ACT_RU_EXECUTION中子执行流是否正常汇聚失败对比nrOfCompletedInstances与nrOfInstances检查completionCondition表达式语法性能问题监控SEQUENCE_COUNTER_增长趋势检查历史表数据量是否过大-- 典型排查查询 SELECT VAR.NAME_, VAR.TEXT_, EXEC.ACT_ID_, EXEC.IS_ACTIVE_, TASK.NAME_, TASK.ASSIGNEE_ FROM ACT_RU_EXECUTION EXEC LEFT JOIN ACT_RU_VARIABLE VAR ON VAR.EXECUTION_ID_ EXEC.ID_ LEFT JOIN ACT_RU_TASK TASK ON TASK.EXECUTION_ID_ EXEC.ID_ WHERE EXEC.PROC_INST_ID_ 异常实例ID;6. 高级调试技巧对于需要深度调试的场景可以启用Camunda的数据库日志配置日志级别# log4j.properties log4j.logger.org.camunda.bpm.engine.persistenceDEBUG关键日志事件对应表变化日志事件涉及表变化典型SQL观察语句创建并行分支ACT_RU_EXECUTION新增记录SELECT * FROM ACT_RU_EXECUTION WHERE PARENT_ID_ 父ID完成任务ACT_HI_ACTINST更新SELECT END_TIME_ FROM ACT_HI_ACTINST WHERE ACT_ID_任务ID变量同步ACT_RU_VARIABLE值变化SELECT TEXT_ FROM ACT_RU_VARIABLE WHERE NAME_nrOfInstances在开发环境中结合数据库监控工具如DBeaver的数据变化跟踪功能可以实时捕捉表记录变化比单纯依赖日志更直观。

相关文章:

Camunda并行会签实战:从BPMN设计到数据库状态变化的完整追踪

Camunda并行会签实战:从BPMN设计到数据库状态变化的完整追踪 在复杂业务流程自动化领域,并行会签是一种常见但实现难度较高的模式。当三个部门主管需要同时审批一份采购申请时,传统串行审批会导致效率低下,而并行处理又面临状态同…...

为什么英语是编程最重要的前置技能?Newbie-Guideline揭示成功秘诀

为什么英语是编程最重要的前置技能?Newbie-Guideline揭示成功秘诀 【免费下载链接】Newbie-Guideline 컴퓨터과학/공학 신입생 및 비전공자 신입을 위한 지침서 项目地址: https://gitcode.com/gh_mirrors/ne/Newbie-Guideline 在编程学习的道路上&#xff0…...

Gregwar/Captcha图像效果详解:扭曲、线条、背景与透明度的艺术

Gregwar/Captcha图像效果详解:扭曲、线条、背景与透明度的艺术 【免费下载链接】Captcha PHP Captcha library 项目地址: https://gitcode.com/gh_mirrors/capt/Captcha 在PHP验证码开发中,Gregwar/Captcha库以其出色的图像效果和安全性能脱颖而出…...

CANN/asc-devkit Mins矢量计算

Mins(灵活标量位置) 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。 …...

CANN/HCOMM拓扑层级查询

HcclRankGraphGetLayers 【免费下载链接】hcomm HCOMM(Huawei Communication)是HCCL的通信基础库,提供通信域以及通信资源的管理能力。 项目地址: https://gitcode.com/cann/hcomm 产品支持情况 Ascend 950PR/Ascend 950DT&#xff1…...

如何快速构建完整的以太坊Go开发实战应用:从入门到精通指南 [特殊字符]

如何快速构建完整的以太坊Go开发实战应用:从入门到精通指南 🚀 【免费下载链接】ethereum-development-with-go-book 📖 A little guide book on Ethereum Development with Go (golang) 项目地址: https://gitcode.com/gh_mirrors/et/ethe…...

FreeJoy固件刷写与配置全攻略:从STM32CubeProgrammer到中文版Configurator

FreeJoy控制器全流程实战指南:从固件刷写到高级配置 在开源硬件和DIY控制器领域,FreeJoy项目以其灵活性和低成本优势吸引了大量创客和游戏外设爱好者。不同于商业产品的封闭性,基于STM32F103C8T的FreeJoy解决方案让用户能够完全掌控控制器的每…...

告别卡顿!用ZLMRTCClient.js和Vue3打造超低延迟WebRTC监控播放器(附完整代码)

超低延迟WebRTC监控播放器:基于ZLMRTCClient.js与Vue3的工程实践 在安防监控、智慧园区等对实时性要求极高的场景中,传统流媒体方案如HLS或FLV往往面临3-5秒甚至更高的延迟。这种延迟在关键场景下可能导致严重后果——当监控画面显示"一切正常"…...

嵌入式数据存储终极指南:5分钟快速上手FlashDB超轻量级数据库

嵌入式数据存储终极指南:5分钟快速上手FlashDB超轻量级数据库 【免费下载链接】FlashDB An ultra-lightweight database that supports key-value and time series data | 一款支持 KV 数据和时序数据的超轻量级数据库 项目地址: https://gitcode.com/gh_mirrors/…...

【习题02】打印菱形

题目: 用C语言在屏幕上输出以下图案:1、题目分析: 这道题目需要打印一个菱形,经过分析可得每一行就是打印空格和*。 经过观察可得: 第一行:6个空格 1个*第二行:5个空格 3个*第三行:4…...

【习题01】喝汽水问题

题目:喝汽水,1瓶汽水1元,2个空瓶可以换一瓶汽水,给20元,可以喝多少汽水(编程实现)。 1、题目解析: 通过分析,我们可以得到以下流程图:20元钱,&…...

智能视觉瞄准系统:基于YOLOv8的高效游戏辅助解决方案

智能视觉瞄准系统:基于YOLOv8的高效游戏辅助解决方案 【免费下载链接】RookieAI_yolov8 基于yolov8实现的AI自瞄项目 AI self-aiming project based on yolov8 项目地址: https://gitcode.com/gh_mirrors/ro/RookieAI_yolov8 RookieAI_yolov8是一个基于先进视…...

3分钟解决Cursor试用限制:设备标识重置完整指南

3分钟解决Cursor试用限制:设备标识重置完整指南 【免费下载链接】go-cursor-help 解决Cursor在免费订阅期间出现以下提示的问题: Your request has been blocked as our system has detected suspicious activity / Youve reached your trial request limit. / Too …...

完全掌握Visual C++运行库:从DLL缺失到系统稳定的全面解决方案

完全掌握Visual C运行库:从DLL缺失到系统稳定的全面解决方案 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 当您在Windows系统中运行游戏或专业软件…...

白介素-5(IL-5)的结构、功能及医学应用研究进展

摘要白介素-5(Interleukin-5,IL-5)是一种由Th2细胞、嗜酸性粒细胞祖细胞等免疫细胞分泌的多功能细胞因子,在调节免疫反应、尤其是嗜酸性粒细胞(Eosinophil, EOS)的分化、存活及功能活化中发挥核心作用。自1…...

Komanda代码嵌入功能详解:Gist、JSFiddle和Twitter无缝集成

Komanda代码嵌入功能详解:Gist、JSFiddle和Twitter无缝集成 【免费下载链接】komanda The IRC Client For Developers 项目地址: https://gitcode.com/gh_mirrors/ko/komanda Komanda作为一款面向开发者的IRC客户端,提供了强大的代码嵌入功能&…...

使用curl命令直接测试taotoken api的连通性与基础功能

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 使用curl命令直接测试taotoken api的连通性与基础功能 基础教程类,面向需要快速验证或在不便安装SDK的环境中进行操作的…...

【热门开源项目下载】yolo-onnx-java

【热门开源项目下载】yolo-onnx-java 1. 项目基础介绍与编程语言 yolo-onnx-java 是一个基于Java语言开发的轻量级AI模型调用框架,专注于为Java开发者提供高效、便捷的深度学习模型推理能力。项目通过ONNX(Open Neural Network Exchange)格式…...

BooruDatasetTagManager自定义界面与快捷键:打造个性化工作流程的终极指南 [特殊字符]

BooruDatasetTagManager自定义界面与快捷键:打造个性化工作流程的终极指南 🎨 【免费下载链接】BooruDatasetTagManager 项目地址: https://gitcode.com/gh_mirrors/bo/BooruDatasetTagManager BooruDatasetTagManager是一款强大的AI训练数据标签…...

DepHell与Docker集成:容器化Python应用开发的终极指南

DepHell与Docker集成:容器化Python应用开发的终极指南 【免费下载链接】dephell :package: :fire: Python project management. Manage packages: convert between formats, lock, install, resolve, isolate, test, build graph, show outdated, audit. Manage ven…...

测试TVS:SP0503BAHTG

简 介: 本文测试了SP0503BAHTG三通道TVS二极管阵列的特性。通过设计测试电路板,测量了该器件对1kHz正弦波的限幅效果,测得反向导通电压约-0.8V,顶部饱和电压6.3V。在1MHz高频测试中观察到快速响应特性,通过矩形波上升沿…...

YOLO-ONNX-Java分布式推理架构设计与实现

YOLO-ONNX-Java分布式推理架构设计与实现 引言:单机推理的性能瓶颈 在实际的AI视觉识别项目中,随着业务规模的扩大,单机推理往往面临以下挑战: 并发处理能力有限:单台服务器无法同时处理大量视频流GPU资源利用率低&…...

别再截图了!用AD21把PCB 3D模型直接塞进PDF,客户评审一目了然

用AD21将PCB 3D模型嵌入PDF:提升设计评审效率的终极方案 在硬件开发流程中,设计评审环节往往成为项目推进的瓶颈。传统方式下,工程师不得不反复截取多角度2D图纸,或录制繁琐的演示视频,既耗费时间又难以全面展示设计细…...

从蓝牙时钟到通用Timer:详解非32位满量程下的时间回环处理技巧

从蓝牙时钟到通用Timer:非标准位宽下的时间回环处理实战指南 在嵌入式系统中,时间管理如同隐形的骨架,支撑着各类关键功能的稳定运行。当开发者从32位通用定时器转向蓝牙协议栈中的28位时钟,或面对某些硬件平台上的24位专用定时器…...

YOLO-ONNX-Java 性能监控指标全面解析

YOLO-ONNX-Java 性能监控指标全面解析 概述 在计算机视觉应用中,性能监控是确保系统稳定运行的关键环节。YOLO-ONNX-Java 作为一个纯 Java 实现的 AI 视觉识别项目,提供了丰富的性能监控指标来帮助开发者优化系统性能。本文将深入解析该项目的性能监控指…...

分布式事务解决方案TCC实战

分布式事务解决方案TCC实战 一、分布式事务概述 在分布式系统中,事务跨越多个服务或数据库,传统的ACID事务无法直接适用,需要采用分布式事务解决方案。 1.1 分布式事务挑战 挑战说明网络延迟跨服务调用存在网络延迟和超时数据一致性多个数据源…...

CANN/catlass精度分析基础

精度分析基础 【免费下载链接】catlass 本项目是CANN的算子模板库,提供NPU上高性能矩阵乘及其相关融合类算子模板样例。 项目地址: https://gitcode.com/cann/catlass 写在前面 该文档主要说明CATLASS样例开发中精度分析的基础知识,包括样例精度…...

一套代码适配四种屏幕——StyleConfiguration 键盘多设备适配方案

文章目录问题在哪?StyleConfiguration 的设计思路KeyStyle 接口定义StyleConfiguration.getInputStyle 完整逻辑资源文件命名规范组件如何使用 StyleConfiguration屏幕旋转适配完整流程这种设计模式的通用价值踩坑记录写在最后搞输入法开发最头疼的事情之一就是屏幕…...

深入理解ops-tensor架构:模块化算子库的设计哲学与实现

深入理解ops-tensor架构:模块化算子库的设计哲学与实现 【免费下载链接】ops-tensor ops-tensor 是 CANN (Compute Architecture for Neural Networks)算子库中提供张量类计算的基础算子库,采用模块化设计,支持灵活的算…...

CANN/cann-learning-hub:Swan LLM 大模型实战课程

【免费下载链接】cann-learning-hub CANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。 项目地址: https://gitcode.com/cann/cann-learning-hub SwanLab x CANN 社区合作课程 Swa…...