复杂事件处理——Esper入门(示例程序)
前面对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入门(示例程序)的更多相关文章
- python入门示例程序
该实例是raspi和dsp电机运动控制板的串口uart通信: import serial class SerialHandler(): ''' raspi serial for communicati ...
- Spring Data Redis入门示例:程序配置(五)
单机配置 redis.properties配置 #redis的服务器地址 redis.host=127.0.0.1 #redis的服务端口 redis.port=6379 #客户端超时时间单位是毫秒 ...
- Cesium入门2 - Cesium环境搭建及第一个示例程序
Cesium入门2 - Cesium环境搭建及第一个示例程序 Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ 验 ...
- [WCF编程]1.WCF入门示例
一.WCF是什么? Windows Communication Foundation(WCF)是由微软开发的一系列支持数据通信的应用程序框架,整合了原有的windows通讯的 .net Remotin ...
- Maven入门示例(3):自动部署至外部Tomcat
Maven入门示例(3):自动部署至外部Tomcat 博客分类: maven 2012原创 Maven入门示例(3):自动部署至外部Tomcat 上一篇,介绍了如何创建Maven项目以及如何在内 ...
- 【java开发系列】—— spring简单入门示例
1 JDK安装 2 Struts2简单入门示例 前言 作为入门级的记录帖,没有过多的技术含量,简单的搭建配置框架而已.这次讲到spring,这个应该是SSH中的重量级框架,它主要包含两个内容:控制反转 ...
- Spring MVC 入门示例讲解
在本例中,我们将使用Spring MVC框架构建一个入门级web应用程序.Spring MVC 是Spring框架最重要的的模块之一.它以强大的Spring IoC容器为基础,并充分利用容器的特性来简 ...
- Velocity魔法堂系列一:入门示例
一.前言 Velocity作为历史悠久的模板引擎不单单可以替代JSP作为Java Web的服务端网页模板引擎,而且可以作为普通文本的模板引擎来增强服务端程序文本处理能力.而且Velocity被移植到不 ...
- Node.js入门实例程序
在使用Node.js创建实际“Hello, World!”应用程序之前,让我们看看Node.js的应用程序的部分.Node.js应用程序由以下三个重要组成部分: 导入需要模块: 我们使用require ...
随机推荐
- Ubuntu下Android Studio安装、配置和使用
Ubuntu下使用Android Studio开发应用程序,首先需要安装该IDE. 情况1:Ubuntu下安装Android Studio 打开Terminal,执行下述指令: sudo apt-ad ...
- bzoj4447 SCOI2015 小凸解密码 password
传送门:bzoj4447 题解: 调试简直恶心,不过调完发现其实还是挺好写的. 用\(\mathrm{set}\)维护一段\(0\)区间的左右端点,每次最多修改两个点,所以很好维护. 查询的时候在\( ...
- WPF的进度条progressbar,运行时间elapse time和等待spinner的实现
今天用.NET 4.5中的TPL的特性做了个小例子,实现了WPF的进度条progressbar,运行时间elapse time和等待spinner. 先上图吧. 这个例子包含4个实现,分别是同步版 ...
- jquery 的小角落
最近换了工作,在这家公司里,使用了大量的jQuery,闲来无事看看锋利的jQuery,发现好多边边角角的选择器,却能省去一大堆逻辑上的的代码,废话不多说直接上代码. #### jquery 对象与do ...
- 移动设备、手机浏览器Javascript滑动事件代码
以下经过本人测试成功. 测试平台:三星S5830I 操作系统:Android 2.3.6 浏览器:UC浏览器 HTML标准:HTML5 测试了三个事件:touchstart.touchmove 和 t ...
- WCF服务发布到IIS时候,只能根据hostname访问,不能根据IP地址访问的解决办法
本文转载:http://www.cnblogs.com/deerbox/archive/2013/05/13/3076248.html 环境: VS2010 sp1,.net framework 4. ...
- java数组使用技巧
参考网上文章,总结了一下java数组使用技巧,如下: package com.beijing.array; import java.nio.ByteBuffer; import java.util.A ...
- python装饰实现线程同步
import threading def tryfinally(finallyf): u"returns a decorator that adds try/finally behavi ...
- 廖雪锋笔记1---python变量类型
整型:a/b a//b a%b 浮点型:.2 字符串: "" '' r"" r'' '''...''' r'''...'''' 变量值共享:写时复制 NULL型 ...
- iOS--inputView和inputAccessoryView
iOS–inputView和inputAccessoryView 什么是inputView和inputAccessoryView? 如果是UITextField和UITextView,下面是声明文件源 ...