Spark Distinct操作的DAG问题
问题
我创建了一个分成两个节点的List
val list = sc.parallelize(List(1,1,1,1,2,2,2,3,3,4),2)
现在对其进行distinct操作
list.distinct.collect
执行时的DAG图如下所示
请问,这个Stage0中的distinct与Stage1中的distinct的区别。
我是这么理解的,首先distinct在各个节点做一次transformation,然后再shuffle做一次transformation。不知道是否正确。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
spark 不同stage 之间的划分原则是是否有shuffle操作。
这里的不是进行了两次 distinct操作,而是一个distinct操作被划分为两个stage,因为有distinct操作需要shuffle。
如果你仔细看stage0的话,你会发现这里进行的distinct 是mapPartitions。