为了账号安全,请及时绑定邮箱和手机立即绑定

Spark RDD 和 Dataframe 转换优化

Spark RDD 和 Dataframe 转换优化

函数式编程 2023-05-09 14:49:52
我是 Spark 的新手,有以下关于 RDD 和 Dataframes 的高级问题,如果我没记错的话,它们是建立在 RDD 之上的:我知道有两种类型的操作可以在 RDD 上完成,转换和操作。我还了解到,仅当对作为该转换产物的 RDD 执行操作时才执行转换。鉴于 RDD 在内存中,我想知道是否有可能优化这些 RDD 消耗的内存量,请看以下示例:KafkaDF = KafkaDFRaw.select(        KafkaDFRaw.key,        KafkaDFRaw.value,        KafkaDFRaw.topic,        unix_timestamp('timestamp',                       'yyyy-MM-dd HH:mm:ss').alias('kafka_arrival_time')    ).withColumn("spark_arrival_time", udf(time.time, DoubleType())())我有一个 KafkaDFRaw 数据框,我生成了一个名为 KafkaDF 的新 RDD。然后我希望向这个新的 RDD 添加列。我应该将它们添加到现有的 RDD 中吗?像这样:decoded_value_udf = udf(lambda value: value.decode("utf-8"))    KafkaDF = KafkaDF\        .withColumn(            "cleanKey", decoded_value_udf(KafkaDF.key))\        .withColumn(            "cleanValue", decoded_value_udf(KafkaDF.value))或者我应该从上一个数据框创建一个新的数据框吗?像这样:decoded_value_udf = udf(lambda value: value.decode("utf-8"))    KafkaDF_NEW = KafkaDF\        .withColumn(            "cleanKey", decoded_value_udf(KafkaDF.key))\        .withColumn(            "cleanValue", decoded_value_udf(KafkaDF.value))这对内存优化有影响吗?预先感谢您的帮助。
查看完整描述

1 回答

?
MYYA

TA贡献1868条经验 获得超4个赞

每当调用操作时,都会执行优化的 dag 并按照计划使用内存。您可以比较执行计划以了解:

df.explain(true)
df_new.explain(true)

在两者之间创建额外的变量来保存转换不会影响内存利用率。内存要求将取决于数据大小、分区大小、随机播放等。


查看完整回答
反对 回复 2023-05-09
  • 1 回答
  • 0 关注
  • 146 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信