如何设计一个灵活的审批流程

简介: 如何设计一个灵活的审批流程

背景

    如何选择一个合适的审批流程,决定了业务逻辑的复杂度。因此选择合适的审批实现方式很重要。在售后,流程式的代码也较多,因此需要选择一个合适的方式。


一、需求

比如当前的流程存在多个步骤,每个步骤都需要人审批,此时的设计方案如何设计比较好?


二、方案

方案一:

这种模式适用于固定流程和可变长短流程

是基于当前的步骤,建立审批流,比如Activiti、Flowable或者阿里开源的审批流框架等,这个时候,此时每个判断条件放在审批流的排他网关上,也即左右变量上,解决流程上的繁琐判断。但是这样有一个问题:需要有一个专门管理的审批流来管理流程。由于审批流和角色挂钩,因此不免需要和认证中心做交互。如果当前的审批流程比较长,会出现一个问题,审批中心出现异常,我们的审批信息也需要进行回滚。由于审批中心和业务系统不在同一个服务,属于不同的领域,因此需要使用分布式事务来保证事务。这个成本上,会有点大。通常审批流较短的话,使用审批流框架比较方便。


方案二:

这种模式适应于固定流程和长度可变流程。

采用数据库预置全流程的方式,此时全流程事先插入到数据库,此时每个流程都会带上角色信息、金额、类型信息。也即比如根据金额和类型,查询对应的流程的步骤。然后将其待处理流程插入到数据库中。当轮到那个角色审批的时候,就进行对应的审批行为,进行审批。此时不需要审批流框架的加持也能完成这个过程。


改进方式:

但是这种方案还是不够灵活。由此我想到还有一种方式可以实现这种操作。也即在每次插入数据库前,将每个待审批的流程数据结构设计成json的数据结构,json里面带分支状态,结合状态来判断,这样每次执行完成,再增加一个总的状态,这样每次执行完成,就代表这个过程成功了,否则回退一个状态即可。


由于json数据结构,方便扩展,因此每次操作的过程还可以带上sort这个字段,这样方便排序的同时,还方便状态的标注。


出现异常与方案一相比,方便回滚。不会存在分布式事务的问题。

但是方案二有一个问题,就是出现多分支的时候,需要给定一个排序的字段。借助一些属性信息来区分。但是方案一对于多分支的情况,依然适用。


方案三:

通常基于审批流程,如果是固定的,可以基于责任链模式,来设计审批流程。责任链模式最典型的代表就是Sentinel。基于SPI构建出来的典型固定流程的设计模式。其本质类似于链表的数据结构。


三、可视化

当然对于这种模式,最好是有一个界面能够进行维护,这样方便可视化。可视化界面减少运维成本。同时能够带上开关,避免因为流程带来的问题。


四、总结

三种方案,各有各的好,但是相对成本而已,方案二的成本要比方案一的成本要低一些 同时方便维护。但是如果是同一级多分支的情况下,使用专业的工作流更为合理。如果当前的审批比较固定,则选择方案三更为合理,成本小,易于维护。

目录
相关文章
|
2月前
|
UED
点晴OA办公系统如何实现业务表单的自定义设计
在点晴OA办公系统中,业务表单的自定义设计是一项重要的功能,它能够满足企业不同的业务需求,提高工作效率和协作能力。 随着企业的发展,不同的业务部门需要处理各种类型的表单,如人事表单、财务表单、项目表单等。如果这些表单无法根据实际需求进行自定义设计,就会导致工作效率低下、信息不准确、协作困难等问题。因此,实现业务表单的自定义设计是提高企业办公效率和协作能力的重要手段。
26 0
|
4月前
|
数据采集 搜索推荐
标准审批灵活配置助力高效组织流程管理
Dataphin 在 V3.14 版本中对标准审批设置功能进行了全面升级,支持按照标准集粒度对不同数据标准的审批流程进行配置:上线、下线审批可独立配置,支持免审批;此外,Dataphin 支持设置不同模块的审批流程使用的审批系统(内置或第三方审批系统),从而将标准管理流程和且 OA 流程进行更好的结合,助力提升组织流程的管理效率,推动业务发展。
|
9月前
|
供应链 安全
开源进销存系统要具备哪些功能模块?
开源进销存系统主要包括采购、库存、销售和财务管理等环节。本文将介绍进销存应该具备哪些功能,以帮助企业更好地进行业务管理,更快的数字化转型。
134 0
开源进销存系统要具备哪些功能模块?
|
11月前
智能排班系统 【管理系统功能、操作说明——中篇】
智能排班系统 【管理系统功能、操作说明——中篇】
190 1
|
XML 数据格式
工作流 自定义表单 挂靠流程 模块设计方案
工作流 自定义表单 挂靠流程 模块设计方案
235 0
工作流 自定义表单 挂靠流程 模块设计方案
Teambition 用简化的方式解决复杂的协作问题
Teambition是一款简单高效的协作工具。其愿景是用简化的方式解决复杂的协作问题。
311 0
Teambition 用简化的方式解决复杂的协作问题
|
JSON 前端开发 JavaScript
聊聊工作台的可维护性
原文地址:https://yuque.antfin.com/nrdara/asd0u6/rp3na5 本文是在原来[《再谈“面向未来中后台场景”》](https://www.atatech.org/articles/180962) 文章上的进一步实践和探索。 在我们的看来,工作台的前端开发,核心目标就是降本提效。而这背后需要重塑的是生产方式,而生产方式 = 生产力(劳动力 + 生产资料
312 0
|
弹性计算 运维
【技术战疫】运维编排灵活审批场景解决方案
运维编排(OOS) 简介 什么是OOS Operation Orchestration Service,简称OOS,是全面、免费的云上自动化运维平台,提供运维任务的管理和执行。典型使用场景包括:事件驱动运维,批量操作运维,定时运维任务,跨地域运维等,OOS为重要运维场景提供审批,通知等功能。OOS帮您实现标准化运维任务,从而实践运维即代码(Operations as Code)的先进理念。关于
905 0