JBoss BRMS复杂事件处理(CEP)性能基准

等概率 技术来了又去,但是一件事保持不变。

在设计企业解决方案时,我们喜欢使我们的生活更轻松的复杂组件,并且作为建筑师和开发人员,我们一直在寻找使我们的生活更轻松的方法。

一种方法是跟上与感兴趣的技术有关的流行新站点。 另一种方法是,以关于技术主题的书籍,杂志或博客的形式尽可能多地阅读。

介绍

在研究领域中,我们可以更深入,更深入地了解我们感兴趣的技术的根源。 例如,在该站点上,您可以找到我在荷兰奈梅亨的拉德布德大学支持通用信息检索研究时所涉及的一些早期作品 。 这项经验表明,观看更严格和更深入的资源非常有价值,这些资源为我感兴趣的技术领域的各种基于科学的会议贡献了研究论文。

当Mark Proctor指出一项复杂事件处理(CEP)引擎的新比较研究 ,其中包括基于JBoss社区的Drools项目引擎时,是时候深入研究本文并检查与JBoss产品相关的结果了。 本文引用的社区组件是Drools项目的一部分,可以在我们直接支持的JBoss业务规则管理系统(BRMS )和JBoss BPM Suite产品中找到。 使用的社区版本为5.5,该版本已从6.0版及更高版本集成到JBoss BRMS中 。

大事记 我确实意识到并不是每个人都喜欢这些论文中用来证明和支持理论结果的严格的数学基础。 因此,为了向您提供有关社区与产品之间的联系的JBoss相关信息,本文将专注于仅提取Drools的CEP相关结果。

您可以免费下载和阅读在第十届网络战争与安全国际会议(ICCWS-2015)上提交的完整原始论文,作者非常乐意将整个论文放在网上。

总览

本文着眼于一类信息系统,该系统将数据和事件收集在一起,以提供在当今复杂的信息技术环境中审核或维护某种形式的安全性的能力。 他们在论文中将这些系统分类为软件信息和事件管理(SIEM)系统,流行的基于规则的开源规则Drools复杂事件处理(CEP)引擎适合作者评估。

概观 作者认为这些系统的最重要特征是“…相关引擎,该引擎用于标准化,减少,过滤和汇总来自一组异构输入的事件。” 本文有望比较并介绍以下相关引擎的性能评估:

  • 简单事件关联器(SEC)
  • 埃斯珀
  • 结脑
  • Drools,JBoss BRMS和JBoss BPM Suite中的Red Hat支持

本文的其余部分将参考与受支持的JBoss BRMS相关的结果,该结果可产生Drools CEP引擎,作者在本文中将其视为相关引擎。 请记住,JBoss BPM Suite是JBoss BRMS的超集,因此,在本文中,我们选择专注于JBoss BRMS。

测试体系结构使用一组处理规则通过JBoss BRMS CEP组件推动了负载,监视了进度,然后将结果过滤到报告中。 生成事件以触发规则并以预定义的分布。

该论文还指出,对CEP组件进行了优化,以产生可能的最佳结果,但是作者并未提供任何细节说明。 测试是在虚拟化的Xeon CPU X5660处理器(基于Linux的操作系统)上进行的,已分配了4GB的RAM,并且该测试套件有多次运行。

基准测试

最终数取为三个运行中测得的结果的平均值,并反映了基于执行时间和吞吐量(每秒处理的事件)的测量结果。 以下显示事件数量可变的规则数目的规则和规则数量可变的事件数目的结果。

1. 500条规则集的执行时间和吞吐量

事件按比例扩大,规则集的大小保持不变。

  • 1k事件
    • 吞吐量– 125个事件/秒
  • 10k事件
    • 吞吐量– 1111个事件/秒
  • 100k事件
    • 吞吐量– 6250个事件/秒
  • 1百万个事件
    • 吞吐量– 14286个事件/秒

与其他引擎相比,事件集从中到大时,我们看到处理吞吐量显着提高,这是按两倍或三倍来衡量的快速相关引擎。 由于索引和引擎设置的初始成本,较小的事件集几乎看不到变化, Mark Proctor在有关这些结果的文章中指出 。

2.一百万个事件集的执行时间和吞吐量

提供的第二个结果基于单个大型事件集和规则集,它们的大小会不断增长。

  • 20条规则
    • 吞吐量– 21,272个事件/秒
  • 200条规则
    • 吞吐量– 14,925个事件/秒
  • 500条规则
    • 吞吐量– 14,286个事件/秒

这些都是很引人注目的,并且随着规则集规模的扩大,性能也会很好地扩展。 同样,较小的规则集会感觉到引擎设置和索引操作的影响,导致标准时间损失随着工作量的增加而变得可以忽略不计。

我们将保留作者提出的结论作为练习供您阅读,但是毫无疑问,无论大小或规则的复杂性,JBoss BRMS CEP组件都提供了一个强大而强大的引擎来处理事件流。

翻译自: https://www.javacodegeeks.com/2015/08/jboss-brms-complex-event-processing-cep-performance-benchmark.html

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

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

相关文章

Hey,孙叫兽的2020 CSDN年度报告已出炉,请查收!

导读:最近经常看到朋友圈有人分享自己2020年在常用平台的年度报告: 有的人分享了这一年来听了多少首歌,最喜爱听的歌是什么; 有的人分享了这一年来消费了多少钱,最喜欢购买的产品类型是什么; 有的人分享了这…

java实现儿时的超级玛丽游戏

导读:近年来,Java作为一种新的编程语言,以其简单性、可移植性和平台无关性等优点,得到了广泛地应用。J2SE称为Java标准版或Java标准平台。J2SE提供了标准的SDK开发平台。利用该平台可以开发Java桌面应用程序和低端的服务器应用程序,也可以开发Java Applet程序。 “超级玛丽…

MongoDB实战指南(二):索引与查询优化

数据库保存记录的机制是建立在文件系统上的,索引也是以文件的形式存储在磁盘上,在数据库中用到最多的索引结构就是B树。尽管索引在数据库领域是不可缺少的,但是对一个表建立过多的索引会带来一些问题,索引的建立要花费系统时间&am…

mysql学生选课系统的关系模型_使用PowerDesigner搭建学生选课管理系统(学生老师管理员一体系结构)由基础设计至数据库生成(SQL语句源代码的生成)全过程实例操作...

思考构图大小及范围首先,我们大致的写出要建的几张表,并自定义其Code(所谓Code其实就是自定义一个字段名,因为SQL语句不能由中文)我们可以将不同的表按照不同的类型分开,这样一个类型的表可以一起建并且相互之间的关系不会弄混制作…

java实现飞机大战游戏

导读:现如今,随着智能手机的兴起与普及,加上5G(the 5th Generation mobile communication ,第5代移动通信技术)网络的深入,越来越多的IT行业开始向手机行业转移重心。而手机行业中游戏方面的利润所占比重较大,并且手机游戏大多数则是由Java语言开发研制的。所以我想顺应…

merge语句使用_使用SQL:2003 MERGE语句的奥术魔术

merge语句使用时不时地,由于以下任何原因,我们不得不将INSERT与UPDATE区分开来感到尴尬: 我们必须至少发表两个声明 我们必须考虑性能 我们必须考虑比赛条件 我们必须在[UPDATE; 如果UPDATE_COUNT 0 THEN INSERT]和[INSERT; 如果例外然后…

UVA 10917 Walk Through the Forest

最短路DP Walk Through the ForestTime Limit: 3000MS Memory Limit: Unknown 64bit IO Format: %lld & %llu[Submit] [Go Back] [Status] Description Problem C: A Walk Through the Forest Jimmy experiences a lot of stress at work these days, especially sin…

一文教你用java实现愤怒的小鸟游戏

导读:Java语言是一门面向对象的编程语言,它不但汲取了C语言的各种精髓,而且还抛弃了C语言里晦涩难懂的多继承和指针等概念,所以Java语言具有的特征便是:功能超强和易用实用。Jbox2D中不仅集成了大量物理运动学和机械运…

WinForm - 两个窗体之间的方法调用

方法1: 所有权法//Form1://需要有一个公共的刷新方法public void Refresh_Method(){  //...} //在调用Form2时,要把Form2的所有者设为Form1Form2 f2 new Form2() ;f2.Owner this;f2.ShowDialog() ; //Form2://在需要对其调用者&#xff0…

一文教你用java实现儿时的超级玛丽游戏

导读:近年来,Java作为一种新的编程语言,以其简单性、可移植性和平台无关性等优点,得到了广泛地应用。J2SE称为Java标准版或Java标准平台。J2SE提供了标准的SDK开发平台。利用该平台可以开发Java桌面应用程序和低端的服务器应用程序…

java开发一款雷电游戏

导读:电脑游戏,是指在计算机上能够运转的游戏软件。这种软件具有较强的娱乐性。电脑游戏的创新和发展与硬件、软件的发展紧密相关。它能够给玩家提供一个虚拟的环境,使游戏带给了人们很多的享受和欢乐。雷电游戏因为操作简单,节奏明快,一直是纵轴射击游戏的经典之作。经常…

glassfish_具有GlassFish和一致性的高性能JPA –第2部分

glassfish在我的四部分系列的第二部分中,我将解释将Coherence与EclipseLink和GlassFish结合使用的第一个策略。它描述了配置带有Coherence的JPA支持的Cache所必须采取的步骤,以及如何在GlassFish中使用它。高性能数据存储。 一般的做法 您可以将Coherenc…

java开发一个连连看小游戏

导读:连连看是一种消除类益智游戏,核心要求是在规定的时间内,消除游戏界面中选中的两张相同的图案,直至完全消除所有图案。这款游戏操作简单(只需单击鼠标左键操作)、面向人群广泛,在限时操作的游戏要求下,吸引玩家自发地锻炼观察能力、判断能力和反应能力,故从推出至今…

java枚举的特点_Java中有些好的特性(二):枚举

前言我在写上一篇时,开始选了一个很土的名字“Java超过C#的地方”,然后引起了某些同学的不满,后来修改了个名。我在这里再次申明一下,我没有贬低任何语言之意,纯粹是从一个.NET程序员的角度去看Java,看看是…

java开发一款推箱子游戏

导读:社会在进步,人们生活质量也在日益提高。高强度的压力也接踵而来。社会中急需出现新的有效方式来缓解人们的压力。此次设计符合了社会需求,Java推箱子游戏可以让人们在闲暇之余,体验游戏的乐趣。具有操作简单,易于上手的特点。 推箱子游戏的玩法十分简单——控制人物绕…

java ee技术_Java EE 6与Spring Framework:技术决策过程

java ee技术在过去的几个月中,我们经历了这个决策过程:为Java平台上的企业开发选择哪种技术堆栈? 有多种选择。 但是,我们深入讨论的是:纯Java EE 6堆栈与带有Java EE的Spring。 以下博客文章总结了当您考虑这些技术堆…

java开发一款坦克大战游戏

导读:随着人们对生活质量的要求一天比一天高,为了让人们更好地开掘自身的智慧,游戏就此进入了大众的视野,在人们的生活中有着重要的位置,已然变得必不可少。游戏产业推动高新技术不断升级,极大地促进了经济的增长,推动了“第四产业”的经济腾飞。坦克大战游戏是童年时期…

java大转盘抽奖概率算法_幸运大转盘抽奖 抽奖算法 程序实现逻辑

近期碰到的一个需求,实现一个类似大转盘抽奖的功能,需自定义奖项,各奖项中奖概率,当日抽奖最大次数,抽奖成本等。分享一个简单的java代码的实现的思路,有不足之处感谢各位指正。初步方法首先要定义几个奖品…

java开发银行柜员业务绩效考核系统

导读:当今社会己进入信息社会时代,信息己经受到社会的广泛关注,被看作社会和科学技术发展的三大支柱(材料、能源、信息)之一。信息是管理的基础,是进行决策的的基本依据。在一个组织里,信息己作为人力、物力、财力之外的第四种能源,占有重要的地位。然而,信息是一种非…

一文教你使用java开发一款坦克大战游戏

导读:随着人们对生活质量的要求一天比一天高,为了让人们更好地开掘自身的智慧,游戏就此进入了大众的视野,在人们的生活中有着重要的位置,已然变得必不可少。游戏产业推动高新技术不断升级,极大地促进了经济…