gpt4 book ai didi

java - 如何在 Java 中迭代 DStream

转载 作者:行者123 更新时间:2023-11-30 08:37:14 25 4
gpt4 key购买 nike

我是 Spark 编程的新手。我有一个 Spark 流程序,它需要将接收到的 DStream 存储到数据库中。我想迭代我的 Dstream 并将每条记录存储到数据库中。

像这样。

JavaStreamingContext streamingContext = getSparkStreamingContext();

JavaReceiverInputDStream<String> socketTextStream = streamingContext
.socketTextStream("localhost", 8080);

DStream<String> dstream = socketTextStream.dstream();

// Iterate each record from the DStream and push it to DB

方法 2:

这是正确的做法吗?这种方法会带来任何性能提升/问题吗?

socketTextStream.foreachRDD(new Function<JavaRDD<String>, Void>() {
@Override
public Void call(JavaRDD<String> rdd) throws Exception {

List<String> collect = rdd.collect();

for (String string : collect) {

System.out.println(string);
}

return null;
}
});

最佳答案

您可以使用 JavaDStream.foreachRDDJavaRDD.foreach :

JavaStreamingContext streamingContext = getSparkStreamingContext();
JavaReceiverInputDStream<String> socketTextStream = streamingContext
.socketTextStream("localhost", 8080);

socketTextStream.foreachRDD(new VoidFunction<JavaRDD<String>>() {
@Override
public void call(JavaRDD<String> rdd) throws Exception {
rdd.foreach(new VoidFunction<String>() {
@Override
public void call(String s) throws Exception {
// Save data
}
});
}
});

或使用 Java 8 Lambda Expressions :

JavaStreamingContext streamingContext = getSparkStreamingContext();
JavaReceiverInputDStream<String> socketTextStream = streamingContext
.socketTextStream("localhost", 8080);

socketTextStream.foreachRDD((VoidFunction<JavaRDD<String>>) rdd -> {
rdd.foreach((VoidFunction<String>) s -> {
// Save data
});
});

编辑

由于您使用的是 Spark 1.2.0(有点旧,我建议升级(当前最新版本是 1.6.1,截至 2016 年 5 月 22 日)):

socketTextStream.foreachRDD(new Function<JavaRDD<String>, Void>() {
@Override
public Void call(JavaRDD<String> rdd) throws Exception {
rdd.foreach(new VoidFunction<String>() {
@Override
public void call(String s) throws Exception {
// Save data
}
});
return null;
}
});

关于java - 如何在 Java 中迭代 DStream,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37372967/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com