0

访问 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正确更新任务FAILEDUP_FOR_RETRY状态超过 10 分钟来解决这个问题;但我想解决根本问题以避免依赖固定的超时阈值,有什么建议吗?

4

1 回答 1

0

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

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

于 2018-07-17T16:16:14.637 回答