SODBASE CEP学习(四)续:类SQL语言EPL与Storm或jStorm集成-使用分布式缓存

流式计算在一些情况下会用到分布式缓存,从而实现(1)想把统计或计算结果保存在分布缓存中,供其它模块或其它系统调用。(2)某一滑动时间窗口上计数,例如实时统计1小时每个Cookie的访问量,实时统计某商品1天内的销售数量和销售额,实时统计某商家1天内的销售量。由于SODBASE CEP引擎本身集成了Redis分布式缓存接口,同时在Storm上可以方便地使用SODBASE EPL语句。因此,通过Storm with SQL也就可以方便地使用Redis、在Redis上做滑动窗口了。

1.示例操作步骤

功能:实时统计1小时每个Cookie的访问量

1.1制作模型文件

本小节对用到的模型文件建模和单元测试,读者如果时间有限,也可以直接进入下一小节

(1)网上下载一个Redis, 建议使用Redis 3.0以上linux版本,SODBASE CEP已支持与Redis 3.0以上的Redis Cluster集成。如果觉得麻烦想快速把例子跑起来,可以用这个Windows版,解压,默认端口6379启动。

(2)下载SODBASE Studio 2.0.22(sp2)版本以上

下载示例CEP模型cookie00.sod、cookie01.sod、cookie02.sod、cookie03.sod

(3)运行SODBASE Studio,导入cookie00.sod、cookie01.sod、cookie02.sod、cookie03.sod

读者可以查看各个模型的EPL语句,和输入输出配置。

cookie00:模拟Cookie实时生成数据,连接到cookie01的输入

cookie01:有两个输出适配器(输出适配器一个重要功能是动作执行),一个添加新数据,一个过期化旧数据,从而在缓存保持10秒滑动窗口。

cookie02:一个输出适配器,查询计数值

cookie03:屏幕输出

(4)将4个EPL模型全部测试运行起来

(5)输出结果

(6)为了在Storm中使用EPL模型,将cookie03的输出配置为storm输出。将cookie01、cookie02、cookie03转化为XML模型文件。cookie00不需要,下面步骤在Storm中写了一个Spout作数据来源。

1.2 编写topology代码

下载最新版示例Storm-EPL-Example,解压后导入到Eclipse中。不用maven,依赖的包都在lib文件夹下,加到build path即可。

开启redis服务器,打开com.sodbase.integration.storm.cookie.CookieSlidingWindowCountTopology.java

Run As->Java Application,就可以在Eclipse中看到输出效果


打包后的jar包可以部署到storm服务器上。

注:使用jStorm的读者,配置方法和Storm一致。在Eclipse工程的lib/storm中使用jstorm依赖的jar包即可。

2. 工作原理

CookieSlidingWindowCountTopology代码如下

package com.sodbase.integration.storm.cookie;
import backtype.storm.Config;
import backtype.storm.LocalCluster;
import backtype.storm.StormSubmitter;
import backtype.storm.topology.TopologyBuilder;
import backtype.storm.tuple.Fields;
import backtype.storm.utils.Utils;

import com.sodbase.integration.storm.PrintBolt;
import com.sodbase.outputadaptor.storm.EPLBolt;

public class CookieSlidingWindowCountTopology {

  public static void main(String[] args) throws Exception {
    TopologyBuilder builder = new TopologyBuilder();
   
    
	/**
	 * EPLBolt相关配置
	 */
    //(1)Bolt的tuple连到EPL哪个流输入上面    
    String streamname="cookie01.input";
    //(2)输出的字段,与EPL输出对应
    Fields outputFields = new Fields("CountIn10Sec","cookieid");
    //(3)EPL引擎cep home
    String cep_home="cep_home";
    //(4)EPL模型文件
    String[] cepmodelfiles=new String[]{
    		//update sliding window with redis
    		"cep_home/files/cookieexample/cookie01.xml",
    		//count
    		"cep_home/files/cookieexample/cookie02.xml",
    		//emit
    		"cep_home/files/cookieexample/cookie03.xml",
    		};

    builder.setSpout("event", new RandomCookieSpout(), 1);
    builder.setBolt("EPL", new EPLBolt(streamname,outputFields,cep_home,cepmodelfiles), 1).shuffleGrouping("event");
    builder.setBolt("print1", new PrintBolt(), 1).shuffleGrouping("EPL");

    Config conf = new Config();
    conf.setDebug(false);

    if (args != null && args.length > 0) {
      conf.setNumWorkers(3);

      StormSubmitter.submitTopology(args[0], conf, builder.createTopology());
    }
    else {

      LocalCluster cluster = new LocalCluster();
      cluster.submitTopology("test", conf, builder.createTopology());
      Utils.sleep(1000000);
      cluster.killTopology("test");
      cluster.shutdown();
    }
  }
}

参考:

SODBASE CEP学习(四):类SQL语言EPL与Storm或jStorm集成

SODBASE CEP学习(四)续:类SQL语言EPL与Storm或jStorm集成-滑动窗口

SODBASE CEP学习进阶篇(七):SODBASE CEP与Spark streaming集成

SODBASE CEP学习进阶篇(五):与分布式缓存集成

SODBASE CEP用于轻松、高效实施数据监测、监控类、实时交易类项目微笑EPL语法见SODSQL写法与示例。图形化建模请使用SODBASE Studio嵌入式方式编程参见运行第一个EPL例子。与Storm集成参见EPL与Storm集成


开发者社区活动,SODBASE产品的用户现在可以领礼品 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值