码迷,mamicode.com
首页 > 其他好文 > 详细

Spark 累加器实验

时间:2017-06-21 19:50:47      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:spark

以下代码用 Pyspark + IPython 完成


统计日志空行的数量:

读取日志,创建RDD:

myrdd = sc.textFile("access.log")


  1. 不使用累加器:

In [68]: s = 0
In [69]: def f(x):
    ...:     global s
    ...:     if len(x) == 0:
    ...:         s += 1
    ...:
In [70]: myrdd.foreach(f)
In [71]: print (s)

得出结果为:

0

原因是python 的变量,即使是全局变量不能应用在各个计算进程(线程)中同步数据,所以需要分布式计算框架的变量来同步数据,Spark 中采用累加器来解决:


  1. 使用累加器

In [64]: s = sc.accumulator(0)
In [65]: def f(x):
    ...:     global s
    ...:     if len(x) == 0:
    ...:         s += 1
    ...:
In [66]: myrdd.foreach(f)
In [67]: print (s)

得出正确结果:

14



本文出自 “恩墨大数据学院-孟硕” 博客,请务必保留此出处http://enmobda.blog.51cto.com/11983635/1940586

Spark 累加器实验

标签:spark

原文地址:http://enmobda.blog.51cto.com/11983635/1940586

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!