【问题标题】:Run python_wheel_task using Databricks submit api使用 Databricks 提交 api 运行 python_wheel_task
【发布时间】: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


    【解决方案1】:

    我相信这应该可以通过指定libraries 字段(请参阅docs)来实现,尽管我不记得在现有集群上将如何处理它(现在无法检查)。你可以试试这样的:

    {
      "existing_cluster_id": <cluster_id>,
      "python_wheel_task": {
        "package_name": <package_name>,
        "entry_point": <entry_point>
      },
      "libraries": [
        { "whl": "dbfs:/FileStore/my-lib.whl" }
      ]
    }
    

    【讨论】:

    • 非常感谢您的回答。不幸的是,在将库字段添加到 json 后,我仍然遇到相同的错误。我更新了我的问题以反映应用的更改。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2020-11-04
    • 2021-09-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-07-16
    • 1970-01-01
    相关资源
    最近更新 更多