zl程序教程

您现在的位置是:首页 >  后端

当前栏目

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

Spark解密 机制 39 Broadcast
2023-09-27 14:26:47 时间

第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的时候,我们可以实现一些“技术福利”,例如在A