package com.zj.storm;
import org.apache.storm.spout.SpoutOutputCollector;
import org.apache.storm.task.TopologyContext;
import org.apache.storm.topology.IRichSpout;
import org.apache.storm.topology.OutputFieldsDeclarer;
import org.apache.storm.tuple.Fields;
import org.apache.storm.tuple.Values;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.Random;
/**
* 产生数据源的
*/
public class CallLogSpout implements IRichSpout {
//Spout输出收集器
private SpoutOutputCollector collector;
private boolean completed = false;
private TopologyContext context;
//上下文
private Random random = new Random();
private Integer idx = 0;
@Override
public void open(Map map, TopologyContext topologyContext, SpoutOutputCollector spoutOutputCollector) {
this.collector = spoutOutputCollector;
this.context = topologyContext;
}
@Override
public void close() {
}
@Override
public void activate() {
}
@Override
public void deactivate() {
}
/**
* 下一个元组
* 一直运行
*/
@Override
public void nextTuple() {
if (this.idx <= 1000) {
List<String> mobileNumbers = new ArrayList<>();
mobileNumbers.add("1234123401");
mobileNumbers.add("1234123402");
mobileNumbers.add("1234123403");
mobileNumbers.add("1234123404");
Integer localIdx = 0;
while(localIdx++ < 100 && this.idx++ < 1000) {
String caller = mobileNumbers.get(random.nextInt(4));
String callee = mobileNumbers.get(random.nextInt(4));
while(caller == callee) {
callee = mobileNumbers.get(random.nextInt(4));
}
Integer duration = random.nextInt(60);
//输出元组
this.collector.emit(new Values(caller, callee, duration));
}
}
}
@Override
public void ack(Object o) {
}
@Override
public void fail(Object o) {
}
/**
* 定义输出的字段名
*
* @param outputFieldsDeclarer
*/
@Override
public void declareOutputFields(OutputFieldsDeclarer outputFieldsDeclarer) {
outputFieldsDeclarer.declare(new Fields("from", "to", "duration"));
}
@Override
public Map<String, Object> getComponentConfiguration() {
return null;
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
stormcalllog.zip (18个子文件)
stormcalllog
pom.xml 792B
src
test
java
main
resources
java
com
zj
storm
CallLogCounterBolt.java 2KB
App.java 1KB
CallLogSpout.java 3KB
CallLogCreatorBolt.java 1KB
.idea
jarRepositories.xml 870B
runConfigurations.xml 346B
workspace.xml 4KB
misc.xml 541B
compiler.xml 545B
.gitignore 184B
target
classes
com
zj
storm
CallLogSpout.class 3KB
CallLogCreatorBolt.class 2KB
CallLogCounterBolt.class 3KB
App.class 2KB
generated-sources
annotations
logs
workers-artifacts
localstorm-1-1677334834
1024
worker.yaml 112B
localstorm-1-1677334986
1024
worker.yaml 112B
localstorm-1-1677335150
1027
worker.yaml 112B
共 18 条
- 1
资源评论
BirdMan98
- 粉丝: 2w+
- 资源: 23
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- Android源码新基线代码更新的方法
- 1_二级程序设计题(34).rar
- 二级程序调试题(填空27+改错7).docx
- HM2314-VB一款N-Channel沟道SOT23的MOSFET晶体管参数介绍与应用说明
- 基于深度学习的危险驾驶检测算法python源码+视频判断是否闭眼或者张开嘴哈欠和吸烟打电话等手势行为功能涵盖7类.zip
- Free-Fs 开源文件管理系统
- HM2314B-VB一款N-Channel沟道SOT23的MOSFET晶体管参数介绍与应用说明
- 毕业设计:Python高校学生学业预警系统(源码 + 数据库 + 说明文档)
- HM2312-VB一款N-Channel沟道SOT23的MOSFET晶体管参数介绍与应用说明
- 毕业设计:Python的在线自主评测系统(源码 + 数据库 + 说明文档)
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功