【转载】esper的官网 http://www.espertech.com/
1.1介绍CEP和事件流分析
Esper引擎是为了满足对事件进行分析并做出反应等这些应用需求而产生的。这些应用要求事实或接近事实处理 事件(或消息)。有时候是为了应对复杂事件处理(CEP)和事件流分析的。关键要考虑这些类型应用的(高)吞吐量、(低)响应时间和需求逻辑的复杂程度 (复杂计算)。esper可以用在股票系统、风险监控系统等等要求实时性比较高的系统中。
1.2 CEP和关系数据库
关系型数据库不适合每秒成百上千的数据量的查询
内存数据库与比传统的关系数据库相比,有更好的查询性能,更适合处理CEP应用。
1.3 专注于CEP的Esper 引擎
这个Esper引擎工作起来有点像数据库的倒置。Esper 引擎允许应用存储查询并运行数据通过,来代替存储数据并且执行查询存储数据的工作方式。esper提供两种机制来处理事件:
1、Esper提供了一个事件模式语言去指定基于表达式的事件模式匹配。这个模式匹配引擎是通过一个状态机来实现的。这个事件处理的方法匹配期望存在的队列或者不存在的事件或者事件的组合。它包括以时间为基础的各个事件之间的关系。
2、 Esper还提供事件流查询。这个样可以使事件流分析CEP应用的需求。事件流查询提供窗口、聚合、连接和分析的函数来处理事件流。这些查询是通过EPL 语句来实现的。EPL用于视图。视图表示需要将构造的数据放入到一个事件流中并且去驱动数据的流动。在数据流动的过程中对数据进行处理,来得到我们最后所 需要的结果。
下面是在网上找到的资料,觉得总结的挺好的:
Esper提供这两种方法作为互补是通过相同的API来实现的
1.4事件驱动应用服务器(Event Driven Application Server)
事 件驱动应用服务器是一种新型的服务器,为每秒需要处理超过100,000个事件的服务器提供一个运行时和多种支撑基础设施服务(如传输、安全、事件日志、 高可靠性和连接器等)。除了事件处理以外,事件驱动服务器还可以将事件信息和长时间存在的数据(通常从关系数据库查询中获取)结合起来,以及在事件流上执 行临时的关联关系和匹配操作。
事件系统(Event System)存在两个概念,可使之与消息传送系统(Messaging System)区分开来:
1、事件流处理(Event Stream Processing,ESP)——检测事件数据流,分析出那些符合条件的事件,然后通知监听器
2、复杂事件处理(Complex Event Processing,CEP)——可以监察各事件间的模式
全 功能的事件驱动服务器尚需数年时间方可实现,但现在开发者就可通过来自Codehaus的Esper,在独立应用、Java企业级应用和Spring应用 中实现事件驱动架构。Esper的1.0版本(InfoQ曾报道过)是在2006年6月发布的,它是一个轻量级、可嵌入的ESP和CEP的开源实现。
把Esper集成到独立应用中其实很简单。步骤如下:
1、获取一个Esper引擎实例
2、生成一个Statement(用Esper的查询语言)
3、使用引擎注册这个Statement
4、生成一个Listener(通过实现一个Java接口,该接口在Statement所得值为true会被触发),并把它跟Statement绑定起来
事件能以Java对象、XML或Map的形式展现,当它们通过系统的时候,系统会评估Statement的值,并执行Listener中的逻辑。
Esper查询语言提供了丰富的语法,这些语法可以表达复杂的临时逻辑,此外还有如下的一些特征:
1、事件过滤
2、滑动窗口和聚集(计算在最近30秒内所有报告的有意义的信息)
3、分组窗口和对输出率的限制(获取最近10分钟内每个区域的信息数量)
4、连接和外连接(允许事件流之间的连接)
5、与历史数据或引用数据集成(访问关系型数据库)
6、生成所有Statement都可以访问的虚拟流
官网的英文简介如下:
http://www.espertech.com/products/esper.php
在官网上借两张图来加深一下理解:
相关推荐
**Esper简介** Esper是Java开发的事件处理引擎,它允许开发者在运行时对持续流入的数据流进行分析和模式识别。Esper支持SQL-like语法,可以方便地定义事件模式和规则,用于实时检测和响应特定的事件序列。 **REST...
**1.1 CEP与事件序列分析简介** 复杂事件处理(Complex Event Processing,简称CEP)是一种用于实时分析和响应大量数据流中的模式的技术。Esper作为一款高性能的CEP引擎,在处理大量事件时表现出色。该章节首先介绍...
#### 四、Esper 简介 Esper 是一种专门用于处理事件流的工具,其设计目的是为了缩短从概念到生产的开发周期。Esper 支持丰富的事件处理语言 (EPL),使得开发者能够快速构建高性能的应用程序。 - **Esper 的特点**...
##### CEP与事件序列分析简介 CEP是一种技术,用于实时地识别、分析和响应复杂的模式或情境,这些模式或情境是由大量简单的事件组成的。Esper通过其特有的事件驱动架构实现了这一目标,能够帮助开发者构建出能够...
Esper简介与事件流处理 - **Esper**:Esper是一款专为事件流处理和复杂事件处理(Complex Event Processing, CEP)设计的强大引擎。它能够在事件流中检测到特定模式时触发预定义的动作。 - **应用场景**:Esper...
### Esper参考文档解析 #### 技术概览 **1.1 CEP与事件流分析简介** 复杂事件处理(Complex Event Processing,简称CEP)是一种用于处理和分析大量实时数据的技术,尤其适用于需要快速响应变化的数据环境。在现代...
### Esper 4.3.0 使用手册核心知识点详解 #### 一、技术概览 **1.1 CEP与事件流分析简介** - **CEP(Complex Event Processing,复杂事件处理)**: 是一种用于实时分析大量事件数据的技术,旨在识别出有意义的...
##### 1.1 复杂事件处理与事件流分析简介 复杂事件处理是指在事件流中检测出有意义的模式的过程。这包括但不限于识别事件序列、模式匹配以及聚合操作等。事件流分析则是指对实时事件数据进行分析的技术,通常涉及...
此外,IBM的Stream Base、Borealis、Hstreaming和Esper也是早期的实时计算解决方案。 淘宝在实时计算领域有其独特实践。银河流数据处理平台是一个基于actor模型的分布式流数据计算框架,采用akka作为底层支持,它能...