对基于消息队列的Activiti异步执行器进行基准测试

一点历史

永不停息​​的一件事是,Activiti如何以惊人的规模在一些大型组织中使用。 过去,这导致了各种优化和重构,其中包括异步执行器-替换旧的作业执行器。 对于未启动的用户:这些执行器在流程实例中处理计时器和异步继续。 特别是在过去的两年中,我们已经看到它的使用大大增加。 异步执行器的引入极大地提高了性能。 但是,去年在巴黎举行的社区活动中,我们了解到,在处理大量工作时,执行者使用的查询可能会导致需要进行表扫描。 这永远不是一件好事。

因此,我们知道在完成版本6之前,我们确实要做一件事,那就是重构异步执行器,使它使用的所有查询都变得非常简单。 这确实意味着我们必须将作业数据拆分为与不同类型和状态匹配的各种表,同时仍要使API与以前的Activiti版本兼容。

在过去的几个月中,我们一直在做这些事情(包括许多其他事情),并取得了一些不错的结果和一些新的不错的API,它们丰富了该平台。 我可以在“新的”异步执行程序的工作方式上写另一个博客,但是昨天我已经完成了文档工作,所以,如果您对所有工作方式都感兴趣, 请查看在线文档或检查工具 栏上 的源代码。 v6分支 。

架构设计当然受我们从过去两种实现中学到的知识的影响,但同时也受消息队列系统中概念的影响很大。 设计目标之一是,插入消息队列并运行它应该非常容易,因为我们有一种直觉,认为这将对性能有所帮助。

因此,我们做到了。 由于新的体系结构,使异步执行程序与消息队列一起工作几乎是微不足道的。 如果您对实现感兴趣, 我还会在文档中添加有关此主题的部分。

而且,当然,您知道我,我只是想将这两个执行程序实现相互比较基准��

基准项目

您可以找到我在Github上使用的代码: https : //github.com/jbarrez/queue-based-async-executor-benchmark

基本上,它的工作是使用配置属性文件运行Main.java。

  • 使用适当的配置启动流程引擎(我最近在网上看到一些Activiti基准测试,这些基准测试了Activiti的性能而未使用适当的连接池数据源。很遗憾,但是无论如何。)
  • 如果以“生产者”身份运行,将启动10000个流程实例,每10毫秒一个。 定期的统计信息将被打印到控制台上。
  • 如果以“执行程序”身份运行,则将流程引擎配置为启用异步执行程序。
  • 可以有任意数量的生产者/执行者,但是所有生产者/执行者都进入同一个数据库。

项目中使用的流程定义如下:

截图-2016-07-20-00.37.54-904x412

需要注意的重要一点(在图表上不可见)是,在这个重要的流程定义中,所有服务任务都是异步的。 并行派生之后的服务任务与加入的并行网关一样配置为互斥的 。 这里有两个计时器,其中用户任务上的一个是1秒,子流程上的一个是50分钟。 总而言之,当启动流程实例时,它导致需要执行27个作业才能到达终点。 对于10000个实例,这意味着我们正在有效测试270 000个作业的吞吐量。

请注意,与任何基准测试一样,原始数字说明了一切,但不是全部。 这一切都取决于服务器硬件,实际的流程定义和许多其他细节。 但是,如果在完全相同的硬件上执行完全相同的代码,相对数字确实会给我们带来很多启发。 阅读下一部分时,请记住这一点。

测试环境

所有基准测试都是在Amazon Web Services(AWS)上运行的,生产者/执行者使用EC2服务器,r3.4xlarge(16个vCPU,16个vCPU)上的数据库使用RDS PostgresQL (因为Postgres是一个很棒的数据库,非常容易设置) 122 GiB内存)。

使用以下EC2配置

  • RDS(postgres):r3.4xlarge(16个vCPU,122 GiB内存)
  • 生产引擎:c3.4xlarge(16个vCPU,30 GiB内存)
  • 执行器引擎:c3.8xlarge(32个vCPU,60 GiB内存)

所有的服务器都在欧盟西部地区运行。 因此,所有测试结果都具有真实的网络延迟(没有运行在localhost基准测试上的延迟,因此跳过了网上经常看到的联网)。 当运行上面的项目时,JVM分配了8GB的空间。

我们将使用的指标是作业的吞吐量 ,以作业/秒表示。 简而言之,在测试运行之后,我们验证数据库中的数据是否正确(即10K完成的流程实例),并采用第一个开始时间和最后一个结束时间,这使我们获得了x秒的时间。 则吞吐量为x / 270000(我们知道每个流程实例等于27个作业)。

基线测量

基准测试的第一件事是“基准”,即由线程池支持的常规异步执行程序(即v5中异步执行程序的改进设计)。 在此测试中,我们使用了2台服务器,并进行了以下配置(注意:6.0.0.Beta3实际上是快照版本):

一个 C d
Activiti版本 6.0.0.Beta3 6.0.0.Beta3 6.0.0.Beta3 5.21.0
生产者引擎 1个 1个 1个 1个
执行器引擎 1个 1个 2 2
#池中的线程 32 10 10 10
阻塞队列大小 256 100 100 100

图片4

一些有趣的观察:

我认为配置A会比配置B更好,因为这台机器毕竟有32个CPU,因此将线程池的线程数与此匹配是有意义的。 但是,配置B的设置非常相似,除了只有10个线程和较小的阻塞队列之外,它的性能大大提高(310 vs 210作业/秒)。 一个可能的解释可能是32个线程争用太多? 我确实记得当初选择默认值“ 10”时,我们进行了一些基准测试,其中10是吞吐量最佳的“魔术数”(但我确实认为这取决于所使用的机器。

我希望添加另一个执行程序节点会产生更大的影响,毕竟我们要添加32个CPU的计算机,但是收益很小(310到326)。 我们将学习原因,并在本文的稍后阶段进行修复。

使用Activiti版本5.21.0的配置D使用与配置C相同的设置。但是,改进的版本6的异步执行程序显然在这里胜出(326 vs 266)。 这当然是我们希望的:-)。

到目前为止,我们最好的结果是每秒326个作业 (并使用两台服务器)。

基准线的变化

鉴于以上设置,可以询问运行混合的生产者/执行者时产生的影响。 这是Activiti引擎默认的运行方式:引擎将同时负责启动流程实例并立即执行它们。 这是配置E (与配置C相同,除了两个引擎现在都是生产者/执行者),结果如下所示。 而且显然性能较差。 一种解释可能是机器已经每10毫秒使用10个线程来启动流程实例,这可能导致与异步执行器的10个线程进行相当多的争用。 可能可以对该设置进行很多调整以获得更好的数字,但这不是此博客的目标。 但是结果仍然很有趣。

图片3

因此,考虑到两个执行器引擎胜于一个执行器引擎,合乎逻辑的事情是尝试三个执行器。 这是配置F。

类似于从一个执行程序到两个执行程序,吞吐量提高了。 但不是以一种壮观的线性方式。

图片2

介绍基于消息队列的异步执行器

现在该切换到基于消息队列的异步执行器了,现在我们有了基准编号。 我选择了最新版本的ActiveMQ ,因为我对此很熟悉,并且设置起来非常容易。 我没有花时间调整ActiveMQ,切换持久性策略或尝试替代方法。 因此,那里也可能会有一些利润。

在基准项目中,我将Spring与以下配置一起使用: https : //github.com/jbarrez/queue-based-async-executor-benchmark/blob/master/src/main/java/org/activiti/MyConfigMessageExecutor.java 。 之所以选择Spring,是因为MessageListenerContainer提供了一种简单的方法来使消息队列侦听器可以很好地与多个线程一起工作(否则,JBoss这样的应用程序服务器会为您提供)。 更具体地说,MessageListenerContainer的concurrenConsumers设置允许设置用于以智能方式监听消息的线程数。 是的,该类确实具有很多可能会更好地影响结果的属性,但这又不是重点。 请记住相对数字。

对于此配置,我们使用与config C类似的设置(到目前为止,我们在两台服务器上的最佳结果),称为config G:1个生产者引擎,2个执行者引擎。 请注意,我们现在还在混合中添加了“队列服务器”,它使用的是c3.8xlarge机器(32个vCPU,60 GiB RAM),类似于执行引擎服务器。

结果低于…,它们简直太棒了:在等效设置(但带有额外的消息队列服务器)中的消息队列异步执行程序比基于线程池的异步执行程序快四倍

图片5

一个小的实现说明:我们不得不切换到UUID ID生成器 ,因为吞吐量对于默认值而言太高了。 请记住,UUID生成器比默认生成器慢,结果甚至更棒(因为我们在这里真正谈论的是毫秒)。

有趣的观察!

如果您运行基准测试项目,则会看到它定期吐出一些统计信息,因此您可以跟踪系统中有多少个作业,计时器,用户任务,历史活动实例,流程实例等。

在运行消息队列设置时,从这些数字中可以很清楚地看出一种模式。 基于线程池的异步执行器可以更快地完成流程实例(例如,大约1分钟后,我们看到一批流程实例已完成),而对于基于消息的异步执行器,流程实例实际上都在一个大的突发中完成了。 这表明后者将更多地分散流程实例活动的执行,而基于线程的活动将继续进行直到完成为止。

团队中的一些讨论导致了对此的解释:基于线程池的线程将始终将下一个异步作业传递给执行程序,而基于消息的线程将其放在队列中,在队列中已经有数千条消息正在等待。 现在添加一个事实,即对于流程实例,我们有很多排它异步作业,这意味着对于基于线程池的异步作业,许多线程试图获取流程实例锁,但由于正在执行排他实例而失败。 但是,这项工作没有获得 ,很快就重新开始了。 对于基于消息队列的消息队列,将它们再次添加到消息队列的末尾。 其中有数千条其他消息正在等待。 回到执行此特定消息时,排他锁很可能已经很久了。

这导致在基于线程池的异步执行程序中进行一些重构:删除并重新插入作业,而不是简单地释放作业的锁定,从而有效地模拟了队列行为。 这是修复程序: https : //github.com/Activiti/Activiti/commit/d08a247570336c872bb17ce513c1fb95b3ba47a2#diff-bd9c7efdb4c57462f6fe71641b280942R212 。

在与config C完全相同的设置(称为config H(1个生产者,2个执行程序))中对这些基准进行基准测试,这表明我们此简单的解决方案将吞吐量提高了34%! 现在我们有了一个新的基准

图片6

更好的消息队列异步执行器结果

因此,在消息队列结果(配置G)中,我们使用了10个线程的相当保守的设置来侦听消息。 想法是我们也有10个线程用于线程池。 当然,消息队列使用者从根本上不同于轮询线程:此类使用者与队列具有持久连接,而队列代理实际上将工作推给其使用者。 这应该更有效。 因此,我们尝试了以下配置,在这些配置中,我们改变了使用者(从而消耗了线程)和执行程序节点的数量。

一世 Ĵ ķ 大号
生产者引擎 1个 1个 1个 1个
执行器引擎 2 2 3 3
#消费者/引擎 32 64 32 64

图片9

因此,一个不错的观察结果是,添加更多的消费者是超级有效的。 我们正在达到2222.9作业/秒吞吐量 。 如果您问我,那是非常快的,并且是基于线程池的异步执行器的五倍。

可悲的是,添加更多的执行器机器实际上对性能不利。 我认为瓶颈现在已成为数据库,以及它如何处理大规模进行的所有并发。 当然,我根本没有调整数据库 ,只是常规的RDS postgres实例。 或尝试使用Aurora或Oracle(在我以前的基准测试中获得了最好的结果)。 但是,这里的重点是相对数量 ,而不是挤出吞吐量的最后一部分。 我认为相对数字点已经确定为��

结论

数字说明了一切:基于新消息队列的异步执行器击败了基于线程池的异步执行器。 这是否意味着您必须立即切换? 不, 常规的异步执行器也非常快(436作业/秒仍然很快),但是更重要的是,设置非常简单,因为Activiti引擎可以处理所有事情。 在项目中添加消息队列意味着额外的复杂性:可能会失败或崩溃的另一件事,是额外的监视,维护等。但是,当您执行大量 (我的意思是“很多”)异步工作时,您会重新达到默认异步执行器可以执行的操作的限制,很高兴知道还有替代方法。

我们还要忘记这里得出的另一个结论:版本6中的新异步执行程序实现是对版本5的重大改进!

进一步的工作

当前的实现仅是Spring / JMS。 但是,该实现对于移植到其他系统和/或协议(应用程序服务器,STOMP,AMPQ,AWS SQS等)而言是微不足道的。 对于将成为流行的下一个选择的反馈表示赞赏。

有趣的是,这种基于消息队列的异步执行器使实现“优先级队列”非常简单。 优先级队列是我们许多大型用户所要求的功能:提供特定的流程定义/实例/在特定条件下/…优先级与常规作业相比。 容易想象如何设置多个队列和/或分配更少或更多的使用者以优先使用某些用例。

翻译自: https://www.javacodegeeks.com/2016/07/benchmarking-message-queue-based-activiti-async-executor.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/353210.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2020德勤面试开始了吗_2020公务员面试公告已出,5月28日开始面试

重磅!上海市2020年度考试录用公务员职位报名及面试工作公告出了!报岗时间:2020年5月11日10:00至5月15日18:00岗位调剂:2020年5月18日10:00至5月20日18:00面试时间:2020年5月28日至6月1日面试时需携带哪些证件和材料?答…

阿米洛键盘取消win_阿米洛花旦娘静电容V2键盘测评:不止是一把好看的键盘

文丨me王bigfun社区原文地址:【开箱/测评】阿米洛花旦娘静电容V2键盘,不止是一把好看的键盘 - bigfun序:我想要换一把好的键盘,因为这把雷柏的V500键盘已经跟了我4年,现在的它又老又丑,抚摸起来的手感还很生…

NY : 括号匹配问题

括号配对问题 时间限制&#xff1a;3000 ms | 内存限制&#xff1a;65535 KB难度&#xff1a;3描述现在&#xff0c;有一行括号序列&#xff0c;请你检查这行括号是否配对。 输入第一行输入一个数N&#xff08;0<N<100&#xff09;,表示有N组测试数据。后面的N行输入多…

【代码笔记】Web-ionic-select

一&#xff0c;效果图。 二&#xff0c;代码。 <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>Todo</title> <meta name"viewport" content"initial-scale1, maximum-scale1, user-scalableno…

adf开发_ADF:动态视图对象

adf开发今天&#xff0c;我想写有关动态视图对象的信息&#xff0c;该对象允许我在运行时更改其数据源&#xff08;SQL查询&#xff09;和属性。 我将使用oracle.jbo.ApplicationModule :: createViewObjectFromQueryStmt方法来解决此问题。 我将逐步介绍如何执行此操作 创建…

stm32f407能跑linux吗_跑步能跑进医院?那我该做跑步运动吗?想健康一点太难了...

跑步能跑进医院&#xff1f;那我该做跑步运动吗&#xff1f;想健康一点太难了&#xff0c;小编学生时期最喜欢的课程永远都是体育课&#xff0c;但最头疼的项目却是磨人的800米和1000米&#xff0c;那简直是我的的噩梦&#xff0c;近日&#xff0c;西安一名初中生跑步居然跑进了…

60秒内使用Java 9的Project Jigsaw的JavaFX HelloWorld

到目前为止&#xff0c;您可能已经听说过Java 9的新模块系统&#xff0c;即项目Jigsaw。 如果您不了解Java 9的新模块系统&#xff0c;则应访问Mark Reinhold的论文“模块系统的状态” 。 此外&#xff0c;您还应该访问nipafx Nicolai Parlog的出色博客&#xff0c; 网址为http…

互补输出级采用共集形式是为了使_天津大学胡文平《先进材料》:溶液法制备厘米级高度取向有机晶体阵列,可用于高性能有机场效应晶体管...

有机场效应晶体管(OFET)以其低成本和柔性受到了广泛关注&#xff0c;在显示驱动、射频识别标签和逻辑电路等方面具有潜在应用。包括小分子材料和共轭聚合物在内的可溶性有机半导体(OSCs)由于其可溶液加工而引起了许多研究者的兴趣&#xff0c;这种溶液可加工性可通过在柔性基底…

c++ 显示图片_飞利浦256P1FR显示器一线直连MacBook使用体验分享

前言嗨&#xff0c;大家好&#xff0c;我是默咖&#xff0c;一个喜欢分享的数码控。最近刚忙完给媳妇升级桌面&#xff0c;自己就忍不住想要换一个Type-C直连MacBook Pro的显示器了&#xff0c;不仅仅为了可以单线直连MacBook Pro也是为了减少拓展坞再接一个转接头的麻烦&#…

ghost快速安装系统的详细步骤?

很多时候我们安装系统都是在很快的时间内给安装完毕&#xff0c;不用像原来那样安装一个系统需要一个多小时&#xff0c;有了ghost是比较方便&#xff0c;十几分钟就可以把系统安装完&#xff0c;这也是DIY爱好者的福音&#xff0c;没有事情的时候安装下自己的系统&#xff0c;…

python安装库报错Microsoft visual c++ 14.0 is required问题解决办法

下载安装包安装即可&#xff1a; https://964279924.ctfile.com/fs/1445568-239446865 or http://www.liangchan.net/liangchan/10220.html转载于:https://www.cnblogs.com/stkares/p/9384424.html

Apache PDFBox命令行工具:无需Java编码

在博客文章Apache PDFBox 2中 &#xff0c;我演示了将Apache PDFBox 2用作从Java代码中调用的库来操作PDF。 事实证明&#xff0c;Apache PDFBox 2还提供了可以直接从命令行直接使用的命令行工具 &#xff0c;而无需其他Java编码。 有几种命令行工具可用&#xff0c;我将在本文…

在分析了47,251个依赖关系之后,2016年排名前100的Java库

谁在上面&#xff0c;谁在后面&#xff1f; 我们分析了Github上的47,251个依赖关系&#xff0c;并抽取了前100个Java库 长周末我们最喜欢的消遣是浏览Github并搜索流行的Java库。 我们决定与您分享乐趣和信息。 我们分析了Github上前3,862个Java项目使用的12,059个独特Java库…

tortoise清理本地分支_本地:延庆运污水环卫抽化粪池

北京兴百荣清洁公司是清理排水管道的技术服务中心。提供下水道疏通&#xff0c;化粪池清理&#xff0c;抽污水&#xff0c;化粪池清掏&#xff0c;管道清淤&#xff0c;下水道清洗&#xff0c;化粪池清理&#xff0c;抽粪&#xff0c;管道疏通&#xff0c;雨水管道清理&#xf…

win7(windows 7)系统下安装SQL2005(SQL Server 2005)图文教程

由于工作需要&#xff0c;今天要在电脑上安装SQL Server 2005。以往的项目都是使用Oracle&#xff0c;MS的数据库还真的没怎么用过&#xff0c;安装Oracle已经轻车熟路&#xff0c;但装SQL Server好像还有点小麻烦&#xff0c;所以记录下来&#xff0c;以留备用。 ------------…

抓娃娃机爪不动怎么办_黄子韬吃娃娃菜能把临时牙咬断?种植牙到底结实不结实?...

黄子韬的临时牙上热搜了&#xff0c;最高排名热搜榜第四位。有关牙齿的事儿瞬间让我这个口腔医生来了八卦之心&#xff0c;在看了后面的各种评论之后&#xff0c;我大概梳理清楚这到底是怎么回事了&#xff1a;小时候因为调皮所以摔断了门牙&#xff0c;前些日子门牙做了种植牙…

抖音数据统计_26万条抖音数据背后的推荐逻辑以及严重失调的男女比例

本文作者&#xff1a;喜哥&#xff08;张佳&#xff09;易灵微课《数据分析-认知与实践》讲师新榜数据分析师人人都是产品经理、华尔街见闻专栏作家简书科技类优秀作者本文首发自公众号喜新&#xff08;noyanjiu&#xff09;,如需转载请注明出处这次是26W条数据&#xff0c;应该…

SQL SERVER 数据库主键和外键的思考

SQL SERVER 数据库主键和外键的思考 什么是主键&#xff1a; 主键是指表中一个列或者列的组合&#xff0c;其值能够唯一的标识表中的每一个行。这样的一列或者多列成为表的主键&#xff0c;通过它可以强制表的实体完整性。当创建或者更改表时可以通过定义PRIMARY KEY约束来创建…

2018/7/31 -zznu-oj -问题 C: 磨刀- 【扩展欧几里得算法的基本应用】

问题 C: 磨刀 时间限制: 1 Sec 内存限制: 128 MB提交: 190 解决: 39[提交] [状态] [讨论版] [命题人:admin]题目描述 磨刀是一个讲究的工作&#xff0c;只能在n℃下进行&#xff0c;所以我们首先要做的就是把刀的表面温度提升到n℃。处理刀身温度有两种方式&#xff1a;1.淬火…

统计各个函数的耗时_分享一次CMS GC耗时狠高优化过程全记录

1. 背景多个业务线的应用出现LongGC告警最近一段时间&#xff0c;经常收到CAT报出来的Long GC告警(配置为大于3秒的为Longgc)。2. 知识回顾2.1 JVM堆内存划分新生代(Young Generation)新生代内被划分为三个区&#xff1a;Eden&#xff0c;from survivor&#xff0c;to survivor…