根據預設,每項工作最多執行 10 分鐘:您可以將此時間縮短,或延長至最多 168 小時 (7 天)。預先發布版支援超過 24 小時的逾時時間。
如本頁所述,您可以設定工作逾時。工作執行沒有明確的逾時時間:所有工作完成後,工作執行就會完成。
單位會指定時間長度。您可以指定逾時時間長度,以秒、分鐘或小時為單位,並以整數值表示。舉例來說,如要將逾時時間長度設為 10 分鐘 5 秒,請將值指定為 605
秒。
如果作業已啟用重試功能,逾時設定會套用至每個工作嘗試。如果工作嘗試未在這段時間內完成,系統就會停止。工作執行時間越長,越可能發生導致工作失敗的問題,例如下游依附元件失敗、記憶體不足錯誤或基礎架構問題。建議您為所有工作啟用重試功能,尤其是長時間執行的工作。
維護事件
工作會定期進行維護。在維護作業期間,任何進行中的工作都會從目前的機器遷移至其他機器。遷移作業進行時,處理作業會暫停一小段時間。
遷移程序會保留工作狀態,但有一個明顯的例外狀況:維護事件期間,外送虛擬私有雲網路連線會中斷。建議您使用可處理偶爾連線重設的用戶端程式庫。
每當工作開始和完成遷移時,Cloud Run 都會列印記錄訊息。
此外,如要以特定方式監控或處理維護事件,可以擷取 SIGTSTP
信號,這個信號會在工作遷移前 10 秒傳送。遷移後,工作會在重新啟動後立即收到 SIGCONT
信號。
下列 Go 範例是可擷取這些信號並輸出記錄項目的函式:
func testSignals() { sigs := make(chan os.Signal, 1) signal.Notify(sigs, syscall.SIGTSTP, syscall.SIGCONT) go func() { for { sig := <-sigs log.Printf("Got Signal: %v", sig) } }() }
必要的角色
如要取得設定 Cloud Run 作業所需的權限,請要求管理員授予下列 IAM 角色:
-
Cloud Run 開發人員 (
roles/run.developer
) 在 Cloud Run 工作上 -
服務帳戶使用者 (
roles/iam.serviceAccountUser
) 服務身分
如需與 Cloud Run 相關聯的 IAM 角色和權限清單,請參閱 Cloud Run IAM 角色和 Cloud Run IAM 權限。如果 Cloud Run 作業與Google Cloud API (例如 Cloud 用戶端程式庫) 介接,請參閱服務身分設定指南。 如要進一步瞭解如何授予角色,請參閱部署權限和管理存取權。
設定工作逾時時間
如要為 Cloud Run 工作指定工作逾時時間,請按照下列步驟操作:
控制台
前往 Google Cloud 控制台的 Cloud Run 作業頁面:
從選單中選取「工作」,然後按一下「部署容器」,填寫初始工作設定頁面。如要設定現有工作,請選取該工作,然後按一下「編輯」。
按一下「容器、磁碟區、連線與安全性」,展開工作屬性頁面。
按一下「一般」分頁標籤。
- 在「工作逾時」欄位中,指定目前工作的工作時間上限,然後選取「時間單位」。您只能以秒、分鐘或小時為單位,將逾時時間長度指定為整數值。舉例來說,如要將時間長度設為 10 分 5 秒,請在「工作逾時」欄位中指定
605
,並將「時間單位」選為「秒」。
- 在「工作逾時」欄位中,指定目前工作的工作時間上限,然後選取「時間單位」。您只能以秒、分鐘或小時為單位,將逾時時間長度指定為整數值。舉例來說,如要將時間長度設為 10 分 5 秒,請在「工作逾時」欄位中指定
按一下「建立」或「更新」。
gcloud
建立工作時:
gcloud run jobs create JOB_NAME --image IMAGE_URL --task-timeout TIMEOUT
取代
- JOB_NAME 改為您的工作名稱。
- IMAGE_URL,並參照容器映像檔,例如
us-docker.pkg.dev/cloudrun/container/job:latest
。 - TIMEOUT,並指定工作任務的最長時間長度,以及時間量和單位,例如
10m5s
代表十分五秒。
如要更新工作:
gcloud run jobs update JOB_NAME --task-timeout TIMEOUT
YAML
如果您要建立新工作,請略過這個步驟。 如要更新現有工作,請下載其 YAML 設定:
gcloud run jobs describe JOB_NAME --format export > job.yaml
更新
timeoutSeconds:
屬性:apiVersion: run.googleapis.com/v1 kind: Job metadata: name: JOB spec: template: spec: template: spec: containers: - image: IMAGE timeoutSeconds: TIMEOUT
取代:
- JOB_NAME 改為您的工作名稱。
- IMAGE_URL,並參照容器映像檔,例如
us-docker.pkg.dev/cloudrun/container/job:latest
。 - TIMEOUT,並指定工作任務的最長持續時間,包括時間量和單位。您只能以秒、分鐘或小時為單位,將時間指定為整數值。舉例來說,如要將時間長度設為 10 分鐘 5 秒,請指定
605
。
您也可以指定更多設定詳細資料,例如環境變數或記憶體限制。
更新現有工作設定:
gcloud run jobs replace job.yaml
Terraform
如要瞭解如何套用或移除 Terraform 設定,請參閱「基本 Terraform 指令」。
在 Terraform 設定中,將下列項目新增至google_cloud_run_v2_job
資源:查看工作逾時設定
如要查看 Cloud Run 工作目前的任務逾時設定,請按照下列步驟操作:
控制台
前往 Google Cloud 控制台的 Cloud Run 作業頁面:
按一下所需工作,開啟「工作詳細資料」頁面。
按一下「查看及編輯工作設定」。
在設定詳細資料中找出工作逾時設定。
gcloud
使用下列指令:
gcloud run jobs describe JOB_NAME
在傳回的設定中找出工作逾時設定。