1.广播变量
![](https://img.haomeiwen.com/i16647275/88089d4296390ad4.jpg)
1.不使用广播变量的话,Driver每次发送task到executor端去执行,都会携带数据副本,这样容易占用executor端大量的内存空间;
2.如果使用广播变量的话,Driver把数据副本广播出去,交给Executor端的BlockManager管理,这样每次执行Driver端发送过来的task不需要携带数据副本,直接向BlockManager申请就可以了,所有的Task共用一份数据;
![](https://img.haomeiwen.com/i16647275/fba34bef3b276d50.png)
注意事项
能不能将一个RDD使用广播变量广播出去?
不能,因为RDD是不存储数据的。可以将RDD的结果广播出去。
广播变量只能在Driver端定义,不能在Executor端定义。
在Driver端可以修改广播变量的值,在Executor端无法修改广播变量的值。
2.累计器
![](https://img.haomeiwen.com/i16647275/36688d0cd963a7d2.png)
1.
![](https://img.haomeiwen.com/i16647275/d26c29e3d01f8213.png)
注意事项
累加器在Driver端定义赋初始值,累加器只能在Driver端读取,在Excutor端更新spark1.6之后也可以读取。
网友评论