pySpark组件
Last updated
Was this helpful?
Last updated
Was this helpful?
PySpark组件是面向使用Python的Spark用户,用户通过Python编写Spark应用程序,通过PySpark组件完成部署,也支持pyspark的sql功能,本文有部分使用方法介绍(更多用法请参考社区指引:Spark SQL, DataFrames and Datasets Guide )。
和标准的Spark相比,pySpark支持上传Python脚本和实时修改,更加的灵活,而且支持SQL功能,所以我们推荐用来作为数据预处理
执行脚本:通过该配置框上传你的PySpark脚本,必填项
依赖包文件:指定你的PySpark应用程序依赖的包,可以是.py .zip .egg文件,可选项
算法参数:指定你的PySpark应用程序所需的参数,即传给PySpark脚本的参数,可选项
配置资源:指定你的PySpark应用程序用到的配置文件,可选项
其他配置操作与Spark组件类似。
使用PySpark的目的是更好地借助其分布式计算的优势,来解决单机完成不了的计算。如果你在PySpark中仍然是调用常规的Python库做单机计算,那就失去了使用PySpark的意义了。下面举例说明如何编写PySpark分布式计算代码。
PySpark本身就具有类似pandas.DataFrame
的DataFrame
,所以直接使用PySpark的DataFrame
即可,基于PySpark的DataFrame
的操作都是分布式执行的,而pandas.DataFrame
是单机执行的,例如:
上述代码中12行将PySpark的DataFrame
转换成pandas.DataFrame
,然后获取'age'列,注意df.toPandas()
操作会将分布在各节点的数据全部收集到driver上,再转成单机的pandas.DataFrame
数据结构,如果数据量很小还可以接受,但是数据量较大时,就不可取了,其实PySpark的DataFrame
本身支持很多操作,直接基于它实现后续的业务逻辑即可,例如上述代码可以改成:
下面有段代码,将数据全部collect
到driver端,然后使用sklearn进行预处理。
上述代码其实就退化为单机程序了,如果数据量较大的话,collect
操作会把driver的内存填满,甚至OOM,通常基于RDD
或DataFrame
的API可以满足大多数需求,例如标准化操作:
就算RDD
或DataFrame
没有满足你要求的API,你可以自行写一个处理函数,针对每条记录进行处理:
process_fn
或judge_fn
会分发到每个节点上分布式执行,你可以在process_fn
或judge_fn
中使用任何python库(如numpy, scikit-learn等)
更多关于Spark的使用可以参考Spark官方文档