前面对Esper Quick Start & Tutorial进行了简单描述,希望各位看官能够大致了解what is Esper,甚至对how to work有朦朦胧胧的了解。

开发一个Esper事件处理程序,非常简单。开发之前只需要引入 esper-version.jar即可。

下面是一个简单的Esper示例,包括一个事件类(POJO)和一个主运行类。事件类如下:

public class MyEvent {

    private int id;
private String name; public MyEvent(int id, String name) {
this.id = id;
this.name = name;
} public int getId() {
return id;
} public String getName() {
return name;
} }

主运行类如下:

import com.espertech.esper.client.Configuration;
import com.espertech.esper.client.EPAdministrator;
import com.espertech.esper.client.EPRuntime;
import com.espertech.esper.client.EPServiceProvider;
import com.espertech.esper.client.EPServiceProviderManager;
import com.espertech.esper.client.EPStatement;
import com.espertech.esper.client.EventBean;
import com.espertech.esper.client.UpdateListener; public class HelloEsper { public static void main(String[] args) { /* 设置配置信息 */
Configuration config = new Configuration();
config.addEventType("myEvent", MyEvent.class); //添加事件类型定义 /* 创建引擎实例 */
EPServiceProvider provider = EPServiceProviderManager.getDefaultProvider(config); /* 创建statement的管理接口实例 */
EPAdministrator admin = provider.getEPAdministrator();
//admin.createEPL("create schema myEvent as com.esper.test.helloesper.MyEvent");
EPStatement statement = admin.createEPL("select id, name from myEvent"); //创建EPL查询语句实例,功能:查询所有进入的myEvent事件
statement.addListener(new UpdateListener() { //为statement实例添加监听
@Override
public void update(EventBean[] newEvents, EventBean[] oldEvents) {
for(EventBean eb : newEvents) {
System.out.println("id:"+eb.get("id") + " name:"+eb.get("name"));
}
}
}); /* 引擎实例运行接口,负责为引擎实例接收数据并发送给引擎处理 */
EPRuntime er = provider.getEPRuntime();
er.sendEvent(new MyEvent(1,"aaa")); //发送事件
} }

其中,事件类,各个属性必需包括getter-method。getter-method的写法必需符合JAVA BEAN约定规则。如下:

主运行类,也就是Esper处理程序的开发步骤基本如下:

1> 创建Configuraiton实例,配置事件类型、plug-in扩展、关系型数据库的访问参数等。

2> 创建引擎实例EPServiceProvider,可通过加载Configuration获取指定配置的引擎实例;获取引擎实例时,也可以指定引擎实例名——engineURI。可以参考API。

3> 创建EPAdministrator,用于注册EPL,获取EPStatement实例。

4> 为EPStatement添加监听或者subscriber,获取引擎处理数据。(在后续的更新中,会比较3种取值方式:监听、subscriber和pull API)

5> 获取引擎运行接口EPRuntime。发送事件。

上面的Esper运行主类中,使用到了configuration。在前两篇中有介绍,Configuration一般不是必须的。所以可以通过如下改造,省去Configuration这一步:

public class HelloEsper {

    public static void main(String[] args) {
//
// /* 设置配置信息 */
// Configuration config = new Configuration();
// config.addEventType("myEvent", MyEvent.class); //添加事件类型定义 /* 创建引擎实例 */
EPServiceProvider provider = EPServiceProviderManager.getDefaultProvider(); /* 创建statement的管理接口实例 */
EPAdministrator admin = provider.getEPAdministrator();
admin.createEPL("create schema myEvent as com.esper.test.helloesper.MyEvent");//通过create schema语法注册 myEvent事件。
EPStatement statement = admin.createEPL("select id, name from myEvent"); //创建EPL查询语句实例,功能:查询所有进入的myEvent事件
statement.addListener(new UpdateListener() { //为statement实例添加监听
@Override
public void update(EventBean[] newEvents, EventBean[] oldEvents) {
for(EventBean eb : newEvents) {
System.out.println("id:"+eb.get("id") + " name:"+eb.get("name"));
}
}
}); /* 引擎实例运行接口,负责为引擎实例接收数据并发送给引擎处理 */
EPRuntime er = provider.getEPRuntime();
er.sendEvent(new MyEvent(1,"aaa")); //发送事件
} }

Esper虽然支持了这种方式来注册事件,但是,仍然建议使用java class的表示事件类型。

【总结】:

Esper事件驱动程序,开发步骤相对来说比较固定,程序实现相对简单,通过几个主要API就能实现复杂事件处理。相对来说,编写满足需要的EPL语句,比较困难,尤其是当模式匹配、事件流或者数据窗口等结合起来使用时。

后续的更新中会对几个核心的API进行说明。EPL也会拿出几个章节进行单独的介绍。

复杂事件处理——Esper入门(示例程序)的更多相关文章

  1. python入门示例程序

    该实例是raspi和dsp电机运动控制板的串口uart通信: import serial class SerialHandler(): ''' raspi serial for communicati ...

  2. Spring Data Redis入门示例:程序配置(五)

    单机配置 redis.properties配置 #redis的服务器地址 redis.host=127.0.0.1 #redis的服务端口 redis.port=6379 #客户端超时时间单位是毫秒 ...

  3. Cesium入门2 - Cesium环境搭建及第一个示例程序

    Cesium入门2 - Cesium环境搭建及第一个示例程序 Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ 验 ...

  4. [WCF编程]1.WCF入门示例

    一.WCF是什么? Windows Communication Foundation(WCF)是由微软开发的一系列支持数据通信的应用程序框架,整合了原有的windows通讯的 .net Remotin ...

  5. Maven入门示例(3):自动部署至外部Tomcat

    Maven入门示例(3):自动部署至外部Tomcat 博客分类:  maven 2012原创   Maven入门示例(3):自动部署至外部Tomcat 上一篇,介绍了如何创建Maven项目以及如何在内 ...

  6. 【java开发系列】—— spring简单入门示例

    1 JDK安装 2 Struts2简单入门示例 前言 作为入门级的记录帖,没有过多的技术含量,简单的搭建配置框架而已.这次讲到spring,这个应该是SSH中的重量级框架,它主要包含两个内容:控制反转 ...

  7. Spring MVC 入门示例讲解

    在本例中,我们将使用Spring MVC框架构建一个入门级web应用程序.Spring MVC 是Spring框架最重要的的模块之一.它以强大的Spring IoC容器为基础,并充分利用容器的特性来简 ...

  8. Velocity魔法堂系列一:入门示例

    一.前言 Velocity作为历史悠久的模板引擎不单单可以替代JSP作为Java Web的服务端网页模板引擎,而且可以作为普通文本的模板引擎来增强服务端程序文本处理能力.而且Velocity被移植到不 ...

  9. Node.js入门实例程序

    在使用Node.js创建实际“Hello, World!”应用程序之前,让我们看看Node.js的应用程序的部分.Node.js应用程序由以下三个重要组成部分: 导入需要模块: 我们使用require ...

随机推荐

  1. html5 文件拖拽上传

    本文首先发表在  码蜂笔记 : http://coderbee.net/index.php/web/20130703/266 html5 文件拖拽上传是个老话题了,网上有很多例子,我一开始的代码也是网 ...

  2. OpenRisc-42-or1200的ALU模块分析

    引言 computer(计算机),顾名思义,就是用来compute(计算)的.计算机体系结构在上世纪五六十年代的时候,主要就是研究如何设计运算部件,就是想办法用最少的元器件(那时元器件很贵),最快的速 ...

  3. android十六进制颜色代码转换为int类型数值

    android开发中将十六进制颜色代码转换为int类型数值方法:Color.parseColor("#00CCFF")返回int数值;

  4. POJ3723 Conscription

    http://poj.org/problem?id=3723 这题虽然简单,但是还是错了很多次. 因为这题构建的图可能是不连通的.也就是说可能有很多棵树. 所以我以前写的并查集用在这上面会出问题的. ...

  5. Linux下Postfix的配置和使用

    Postfix为何物,详见:http://zh.wikipedia.org/wiki/Postfix 0.关于Postfix postfix的产生是为了替代传统的sendmail.相较于sendmai ...

  6. JAVA学习第四十七课 — IO流(一):文件的读写

    输入流和输出流相对于内存 将外部设备的数据读取到内存中:输入 将内存中的数据写入外部设备中:输出 IO流经常使用基类 字节流的抽象基类:InputStream,OutputStream 字符的抽象基类 ...

  7. Xcode常见报错及解决办法

    报错一: 在iOS7的真机运行时,弹出错误:App installation failed. There was an internal API error. 如图 解决办法: 在Xcode -> ...

  8. BootStrap table 传递搜索参数

    看bootStrap table文档不难发现它有一个queryparams属性,是向后台传递参数的,默认参数已有pageSize.pageIndex等,那么怎么传递自定义的参数呢?在网上找了好多也没有 ...

  9. nginx php7 配置 备用

    yum install epel-* -y yum install -y wget unzip gcc gcc-c++ make zlib zlib-devel pcre pcre-devel lib ...

  10. angularjs 将带标签的内容解析后返回

    参考地址:http://okashii.lofter.com/post/1cba87e8_29e0fab 引入angular-sanitize.js文件 注入ngSanitize 页面数据绑定 ng- ...