BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Greg Young:复杂事件处理的应用

| 作者 Jan Stenberg 关注 29 他的粉丝 ,译者 陈晴阳 关注 0 他的粉丝 发布于 2014年2月22日. 估计阅读时间: 3 分钟 | Google、Facebook、Pinterest、阿里、腾讯 等顶尖技术团队的上百个可供参考的架构实例!

在一场报告中,Greg Young指出,复杂事件处理(Complex Event Processing, CEP)非常善于解决与时间相关的问题,比如,用户可能会通过查询历史数据来找出发生在不同时间点上却又互相关联的信息。

Greg认为,事件处理是一种信息处理方式,它通过对已发生事情所产生的数据进行分析,并从中得到有价值的内容。一个比较经典的例子就是在查找发生于不同时间点上的相关信息时所使用的“时间相关的查询”,譬如,在twitter的数据流中,找出那些在说出“生日”一词之后,立刻说出“礼物”的所有用户;再譬如,在同一次临床试验中,找出在不同的时间点上产生类似反应的所有病人。

为了创建这种查询,Greg使用了一种基于JavaScript的查询语言,这种语言可以对事件流进行查询。使用JavaScript来编写查询语句,这就意味着可以使用Web浏览器来编写和调试这些查询语句。

事件存储(Event Store)中就包含了这样一种查询语言。事件存储是基于事件溯源(Event Source)所开发的一种NoSQL数据库。在事件溯源中,对象的状态并非是被直接保存的,而是由一系列发生在某个时间点上的事件所表述的。通过这种方式来保存对象的状态,这就意味着与状态变更相关的所有信息都将被保存下来,而不仅仅是保存当前的状态。

如同乘坐时光机器一样,对事实数据或者说事件的保存,使我们能够很方便地回溯到事情发生的那一刻,并了解到整个事情的发生过程。例如,创建并生成一张本应在一个月前产生的报表。

事件溯源的另一种应用场景就是对未来的预测和对预测结果准确度的评估;比如基于一个月前的情形来执行一套预测模型,得出目前的预测结果,然后与目前的实际情况进行比较。

事件存储是一套基于三条款BSD许可协议(3-clause BSD license)的开源产品,第一个版本发布于2012年9月。

Greg Young是事件存储这套产品的首席架构师,同时也是一位独立顾问,他因提出CQRS这一概念而闻名于世。

原文英文链接:Greg Young on Using Complex Event Processing


感谢邵思华对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT