我正在尝试将用于构建实时数据管道的技术,并且在将内容导出到文件时遇到了一些问题。
我已经设置了一个本地 kafka 集群和一个 node.js 生产者,它发送一条简单的文本消息只是为了测试功能并粗略估计实现的复杂性。
这是从 kafka 读取的 Spark 流作业,我正在尝试将其写入文件。
from pyspark import SparkContext
from pyspark.streaming import StreamingContext
from pyspark.streaming.kafka import KafkaUtils
# Create a local StreamingContext with two working thread and batch interval of 1 second
sc = SparkContext("local[2]", "KafkaStreamingConsumer")
ssc = StreamingContext(sc, 10)
kafkaStream = KafkaUtils.createStream(ssc, "localhost:2181", "consumer-group", {"test": 1})
kafkaStream.saveAsTextFile('out.txt')
print 'Event recieved in window: ', kafkaStream.pprint()
ssc.start()
ssc.awaitTermination()
我在提交 Spark 作业时看到的错误是:
kafkaStream.saveAsTextFile('out.txt')
AttributeError: 'TransformedDStream' object has no attribute 'saveAsTextFile'
不对数据执行任何计算或转换,我只是想构建流程。 我需要更改/添加什么才能导出文件中的数据?
http://spark.apache.org/docs/latest/api/python/pyspark.streaming.html
saveAsTextFiles
(注意复数)
saveAsTextFile
(单数)是 RDD
上的方法,而不是 DStream
。