SparkStreaming 自定义数据采集器
本文的前提条件: SparkStreaming in Java
参考地址:Spark Streaming Custom Receivers
1.自定义数据采集器
package cn.coreqi.receiver;
import org.apache.spark.storage.StorageLevel;
import org.apache.spark.streaming.receiver.Receiver;
import java.util.Random;
/**
* 自定义数据采集器
*/
public class MyReceiver extends Receiver<String> {
private boolean flg = true;
public boolean isFlg() {
return flg;
}
public void setFlg(boolean flg) {
this.flg = flg;
}
public MyReceiver(){
super(StorageLevel.MEMORY_ONLY());
}
/**
*
* @param storageLevel 存储级别
*/
public MyReceiver(StorageLevel storageLevel) {
super(storageLevel);
}
/**
* 启动采集器时的操作
*/
@Override
public void onStart() {
new Thread(() -> {
while (flg){
try {
String message = "采集的数据为:" + new Random().nextInt(10);
store(message);
Thread.sleep(500);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
}
}).start();
}
/**
* 停止采集器时的操作
*/
@Override
public void onStop() {
setFlg(false);
}
}
2.注册并使用
package cn.coreqi;
import cn.coreqi.receiver.MyReceiver;
import org.apache.spark.SparkConf;
import org.apache.spark.streaming.Durations;
import org.apache.spark.streaming.api.java.*;
public class Main {
public static void main(String[] args) throws InterruptedException {
// 创建SparkConf对象
SparkConf sparkConf = new SparkConf()
.setMaster("local[*]")
.setAppName("sparkSql");
// 第一个参数表示环境配置,第二个参数表示批量处理的周期(采集周期)
JavaStreamingContext ssc = new JavaStreamingContext(sparkConf, Durations.seconds(3));
JavaReceiverInputDStream<String> messageDS = ssc.receiverStream(new MyReceiver());
messageDS.print();
// 由于SparkStreaming采集器是长期执行的任务,所以不能直接关闭
// 如果main方法执行完毕,应用程序也会自动结束,所以不能让main执行完毕
ssc.start(); // 启动采集器
ssc.awaitTermination(); // 等待采集器的关闭
}
}
作者:奇
出处:https://www.cnblogs.com/fanqisoft/p/17966182
版权:本作品采用「本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。」许可协议进行许可。
如果文章内容对您有所帮助,欢迎赞赏.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
2019-01-15 在Spring(4.3.22)中集成Hibernate(5.4.0)
2019-01-15 Hibernate5.4的环境搭建