【发布时间】:2022-01-26 12:45:17
【问题描述】:
我想通过提供 package_name 和 entry_point 来使用 api/2.0/jobs/runs/submit API 端点将 Python Wheel 作为 Spark 作业运行:
{
'existing_cluster_id': self.cluster_id,
"python_wheel_task": {
"package_name": "my.package",
"entry_point": "my_method"
},
"libraries": [
{"whl": "dbfs:/FileStore/jars/1e023c35_ca3a_42c0_958b_fa308124ccc3/my_lib-0.0.1-py3-none-any.whl"}
]
}
但是,在处理请求时,Databricks 正在使用 %conda magic 命令(用于使用熟悉的 pip 和 conda 语法管理笔记本范围内的 Python 包依赖项),这些命令在标准 Databricks Runtime(仅 Databricks Runtime ML v6.4+ 支持):
Py4JJavaError: An error occurred while calling t.getCondaEnvState.
: org.apache.spark.SparkException: Conda magic is only available on Databricks Runtime for Machine Learning.
at com.databricks.backend.daemon.driver.PythonDriverLocal$PythonEntryPointInterfaceImpl.getCondaEnvState(PythonDriverLocal.scala:265)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at py4j.reflection.MethodInvoker.invoke(MethodInvoker.java:244)
at py4j.reflection.ReflectionEngine.invoke(ReflectionEngine.java:380)
at py4j.Gateway.invoke(Gateway.java:295)
at py4j.commands.AbstractCommand.invokeMethod(AbstractCommand.java:132)
at py4j.commands.CallCommand.execute(CallCommand.java:79)
at py4j.GatewayConnection.run(GatewayConnection.java:251)
at java.lang.Thread.run(Thread.java:748)
除了使用 spark_python_task 和导入 wheel 的入口点并运行它的脚本之外,还有其他方法可以运行 Python Wheel 吗?
提前致谢。
【问题讨论】:
标签: apache-spark pyspark databricks azure-databricks