说到工做流、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将不会再被自动执行。async
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 的引入,锦上添花,为咱们应对往后更高的负载、并发任务给了更多的信心。队列