Kafka作为源数据进行数据流计算

本文介绍如何使用 Apache Spark Streaming 框架从 Kafka 中读取实时数据流,并实现词频统计功能。具体包括:创建 SparkContext 和 StreamingContext;配置 Kafka 参数;从 Kafka 中读取数据;对数据进行词频统计;最后打印统计结果。
#!/user/bin/env python3

from __future__ import print_function
import sys
from pyspark import SparkContext
from pyspark.streaming import StreamingContext
from pyspark.streaming.kafka import KafkaUtils

if __name__ == "__main__":
	if len(sys.argv)!=3:
		print("Usage:KafkaWordCount.py<zk><topic>", file = sys.stderr)
		exit(-1)
	sc = SparkContext(aapname = "PythonStreamingKafkaWordCount")
	ssc = StreamingContext(sc,1)
	zkQuorum,topic = sys.argv[1:]
	kvs = KafkaUtils.createStream(ssc,zkQuorum,"spark-streaming-consummer",{topic:1})
	lines = kvs.map(lambda x:x[1])
	counts = lines.fatMap(lambda line:lines.split(" ")).map(lambda word:(word,1)).reduceByKey(lambda a,b:a+b)
counts.pprint()
ssc.start()
ssc.awaitTermination()
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值