Spark 不允许在 Worker 中访问 SparkContext

如果 SparkContext 或 SQLContext 被传到 Worker,哪怕实际上在 Worker 中没使用上,都会报下面的错误

Exception: It appears that you are attempting to reference SparkContext from a broadcast variable, action, or transforamtion. SparkContext can only be used on the driver, not in code that it run on workers. For more information, see SPARK-5063.

比如以下几种情况

class Test(object):
    def __init__(self, spark_context):
        self.spark_context = spark_context
        
    def process(self, data):
        return data * 2
        
    def run(self, rdd):
        # 实际上 self.process 并没有用到 self.spark_context, 但还是会报错
        new_rdd = rdd.map(lambda x: self.process(x))
class Test(object):
    spark_context = None

    def __init__(self, spark_context):
        Test.spark_context = spark_context
        
    @staticmethod
    def process(data):
        return data * 2
        
    def run(self, rdd):
        # 实际上 Test.process 并没有用到 Test.spark_context, 但还是会报错
        new_rdd = rdd.map(lambda x: Test.process(x))
class Test(object):
    spark_context = None

    def __init__(self, spark_context):
        Test.spark_context = spark_context
        
    def process(self, data):
        return data * 2
        
    def run(self, rdd):
        # 实际上 self.process 并没有用到 Test.spark_context, 但还是会报错
        new_rdd = rdd.map(lambda x: self.process(x))

改成下面的方式就可以

class Test(object):
    spark_context = None

    def __init__(self, spark_context):
        self.spark_context = spark_context
        
    @staticmethod
    def process(data):
        return data * 2
        
    def run(self, rdd):
        # 调用的是 Test.process,而 spark_context 保存在 self
        new_rdd = rdd.map(lambda x: Test.process(x))

posted @   moon~light  阅读(1987)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 提示词工程——AI应用必不可少的技术
· 地球OL攻略 —— 某应届生求职总结
· 字符编码:从基础到乱码解决
· SpringCloud带你走进微服务的世界
点击右上角即可分享
微信分享提示