您当前的位置: 首页 >  ar

段智华

暂无认证

  • 0浏览

    0关注

    1232博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

第39课:Spark中的Broadcast和Accumulator机制解密

段智华 发布时间:2017-06-04 13:46:05 ,浏览量:0

第39课:Spark中的Broadcast和Accumulator机制解密

Spark的Broadcast和Accumulator很重要,在实际的企业级开发环境中一般会使用Broadcast和Accumulator。Broadcast和Accumulator和RDD是Spark中并列的三大基础数据结构。大家谈Spark的时候首先谈RDD,RDD是一个并行的数据,关注在jvm中怎么处理数据。很多时候可能忽略了Broadcast和Accumulator,这2个变量都是全局级别的,例如集群中有1000台机器,那Broadcast和Accumulator可以在1000台机器中共享。在分布式的基础之上,如果有共享的数据结构,那是非常有用的。

分布式大数据系统中,我们进行编程的时候首先考虑数据结构:

l RDD: 分布式私有数据结构。RDD本身是一个并行化的本地化的数据结构,运行的时候在一个个线程中运行,RDD是私有的运行数据和私有的运行过程,但在一个Stage里面是一样的,一个线程一个时刻只处理一个数据分片,另一个线程一个时刻只处理另一个数据片。在设计业务逻辑的时候,我们通常考虑这个分片如何去处理。

l  Broadcast:分布式全局只读数据结构。

l  Accumulator:分布式全局只写的数据结构。我们不会在线程池中读取Accumulator,但在Driver上可以读取Accumulator。

在生产环境下,我们几乎一定会自定义Accumulator:

1,自定义的时候可以让Accumulator非常复杂,基本上可以是任意类型的Java和Scala对象;

2,在自定义Accumulator的时候,我们可以实现一些“技术福利”,例如在Accumulato

关注
打赏
1659361485
查看更多评论
立即登录/注册

微信扫码登录

0.0971s