【问题标题】:PythonOperator task hangs accessing Cloud Storage and is stacked as SCHEDULEDPythonOperator 任务挂起访问 Cloud Storage 并按 SCHEDULED 堆叠
【发布时间】:2026-01-28 14:10:02
【问题描述】:

访问 Cloud Storage 时,我的 DAG 中的一项任务有时会挂起。似乎代码在此处的download 函数处停止:

hook = GoogleCloudStorageHook(google_cloud_storage_conn_id='google_cloud_default') for input_file in hook.list(bucket, prefix=folder): hook.download(bucket=bucket, object=input_file)

在我的测试中,该文件夹包含一个 20Mb 的 json 文件。

该任务通常需要 20-30 秒,但在某些情况下会运行 5 分钟,之后其状态会更新为 SCHEDULED 并卡在那里(等待超过 6 小时)。我怀疑 5 分钟是由于配置 scheduler_zombie_task_threshold 300 但不确定。

如果我在 Web UI 上手动清除任务,该任务会快速排队并再次正确运行。我通过设置 execution_timeout 来解决这个问题,当它需要超过 10 分钟时,它会将任务正确更新为 FAILEDUP_FOR_RETRY 状态;但我想解决根本问题以避免依赖固定的超时阈值,有什么建议吗?

【问题讨论】:

    标签: google-cloud-composer


    【解决方案1】:

    Cloud Composer 讨论组对此进行了讨论:https://groups.google.com/d/msg/cloud-composer-discuss/alnKzMjEj8Q/0lbp3bTlAgAJ。当 Airflow 工作人员死亡时,Celery 执行器会出现问题。

    虽然 Composer 正在修复,但如果您希望在当前版本中减少这种情况发生的频率,您可以考虑减少并行度 Airflow 配置或创建具有更大机器类型的新环境。

    【讨论】: