文档章节

Activiti 6.0 新特性 速递

6pker
 6pker
发布于 2016/08/22 18:47
字数 679
阅读 3172
收藏 4

说到工作流、Activiti,通常大家脑海里一闪的是:“OA系统”、“表单”、“人工审批流转”。

不可否认,OA系统里的表单审批流转是工作流的典型应用。

但是工作流的应用范围不仅限于此,如果提起工作流、Activiti,你的脑海里一闪而过的是“Timer”、“Job Executor”、“Async Executor”、“Retries”、“Lock Expire Time”、“Thread Pool”等,至少说明你对Activiti已经有了一个进阶的认识。

2016年6月初 Activiti 5.21.0 正式版已经发布,对一些已知的Bug做了修复。
需要特别指出的是,有个令人头疼的bug也在该版本中修复。
即:当一些job被 Activiti Engine 锁定的时候(即act_ru_job这张表里,当lock_exp_time_有值、dudate_为空并且RETRIES_ > 0的时候),如果遇到服务器重启或者服务器宕机,服务器正常后这些被锁定的job将不会再被自动执行。

5.21.0 的发布没有太多亮点,而 Activiti 6.0 有不少新特性值得期待。
在过去的一年里,Activiti团队做出最的令人瞩目的举动是在 5.17.0 开始使用Async Executor,目的在于替代旧的Job Executor。此举大幅度地提高了Activiti处理异步任务的能力和效率。

Activiti团队领袖Joram Barrez曾在博客中表示说,在发布 Activiti 6.0 正式版之前,将会对Async Executor进行优化和重构,让Activiti更加高效地处理高负载高并发任务。

果不其然,临近 Activiti 6.0 正式版的发布,在Activiti的Github上可以看到,Activiti团队对Async Executor进行了颠覆性的重构。

 

截至到今天(2016年8月22),Acitiviti 6.0 最值得期待的新特性,简要概括如下:
1. Activiti 6.0开始,只支持Async Executor。
2. Async Executor 将以可插拔的方式,支持两种模式。
3. 模式1:Thread Pool backed Async Executor(通过线程池实现Async Executor)
4. 模式2:Message Queue based Async Executor(通过消息队列实现Async Executor)
5. ACT_RU_JOB表被拆分,减小了以往处理timer和异步任务时轮询这张表的压力。
6. ACT_RU_JOB表被拆分为了:
        ACT_RU_TIMER_JOB、
        ACT_RU_JOB、
        ACT_RU_DEADLETTER_JOB、
        ACT_RU_SUSPENDED_JOB。
7. Job的重试次数将可配(通过设置asyncExecutorNumberOfRetries的值),默认次数还是为3。

 

由此可以窥见,Activiti 6.0 引入 Message Queue Based Async Executor 后,处理高负载高并发任务的能力将发生质的飞跃。
当然,笔者相信 Thread Pool Backed Async Executor 已经在很大程度满足了绝大多数使用场景的需求。
Message Queue Based Async Executor 的引入,锦上添花,为我们应对日后更高的负载、并发任务给了更多的信心。

 

 

 

© 著作权归作者所有

共有 人打赏支持
6pker
粉丝 54
博文 97
码字总数 59252
作品 0
浦东
程序员
私信 提问
加载中

评论(1)

Wizzer
Wizzer
关注
我的项目是5.22版本,数据库是6.0版本,这样有什么办法可以连接上数据库吗?

我的项目是activiti-explorer的5.22版本,数据库是6.0版本(必须用6.0数据库),这样有什么办法可以连接上数据库吗? 报的错误是 Could not update Activiti database schema: unknown versi...

SpringDu
2018/05/23
210
0
Activiti 5.11 发布,业务流程管理

1. 圣诞大礼包 这是我第一次为Activiti的发布撰文,因为这次的发布我觉得很有必要和大家分享,这其中包含了我期待的新特性和已知问题的修复;而且还有一个重量级的模块Activiti Modeler。 在...

咖啡兔
2012/12/06
5.5K
15
activiti官网下载的6.0的包其中activiti5-engine-6.0.0.jar与activiti-engine-6.0.0.jar 配置信息有什么区别

最近在研究 activiti 6.0 版本 大家都知道6相对于5来说做了很大的改动,像之前活动对象 流程定义的pvm包,在6版本这全部删除了。所有我尝试写了几个demo,在我网上查找6版本所需要的配置时,发...

奋斗的少年ss
2018/04/29
64
0
Activiti 5.0 升级 Activiti 6.0

Activiti 5.0 升级 Activiti 6.0 注意事项

ChrisPaul-
2018/11/01
115
0
Activiti 5.16.4 发布,基于BPMN2.0规范的流程引擎

Activiti 5.16.4 发布,此版本包括 bug 修复,同时也包括两个比较重要的新特性。 Activiti 引入了一个新的锁自由作业执行程序,提升作业执行的幅度可伸缩性(https://github.com/Activiti/A...

oschina
2014/10/20
4.4K
2

没有更多内容

加载失败,请刷新页面

加载更多

Android的WIFI局域网对讲机

https://blog.csdn.net/z979451341/article/details/79280749 (三)Android局域网内语音对讲 基于UDP语音传输 https://blog.csdn.net/stormxiaofeng/article/details/80513947 Android7.0手......

shzwork
42分钟前
2
0
vuex

一直有个误区 vuex既然页面刷新会丢失 那还有什么意义 。 重新翻看了下文档才恍然大误,vuex主要解决的是不同组件间的通信。 跨页面数据共享本质上还是用sessionStorage/localStorage...

东东笔记
今天
3
0
网站漏洞检测之WordPress 5.0.0 修复方案

2019年正月刚开始,WordPress最新版本存在远程代码注入获取SHELL漏洞,该网站漏洞影响的版本是wordpress5.0.0,漏洞的产生是因为image模块导致的,因为代码里可以进行获取目录权限,以及文件...

网站安全
今天
3
0
MySql 优化 group by 语句

默认情况下,Mysql 对所有 group by 的字段进行排序,如果查询包括 group by ,用户想要避免排序结果的消耗。可以指定 order by null 禁止排序。 mysql> EXPLAIN select * from sys_log gro...

嘴角轻扬30
今天
16
0
Linux分区&格式化&文件系统&LVM&扩容

硬件 磁盘由 盘片组、主轴马达、机械臂、磁头、驱动芯片和电路、接口等构成 2. 磁盘的分割 每个盘片很多同心圆分割为磁道 Trace 一组盘片的同径磁道叫做一个柱面 Cylinder 每个磁道又被分为很...

可数局部基
今天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部