累加器用来对信息进行聚合,而广播变量用来高效分发较大的对象。
广播变量
对于经常用到变量值,在分布式计算当中,多个节点task一定会多次请求这个变量就会产生大量网络IO,会影响效率,这是就可以使用广播变量的方式广播到相对应的exector端,以后在使用该变量时就可以直接向本机获取该值计算即可.
累加器:
累加器是Spark提供,用于多个task并发的对某个变量进行操作,task可以定义累加器进行操作,不能读取其值,只有在Driver 才能读取;累加器可以看作静态全局变量
作用:
1.能够准确的统计数据的各种数据例如:可以统计出符合userID的记录数在同一个时间段内产生了多少次购买,可以使用ETL进行数据清洗,并使用Accumulator来进行数据的统计
2.作为调试工具,能够观察每个task的信息,通过累加器可以在sparkIUI观察到每个task所处理的记录数.
简述广播变量和累加器的使用场景以及使用中的注意事项
最新推荐文章于 2025-02-17 08:06:17 发布