在 Cloud Run 中构建并创建 Go 作业
准备工作
- 登录您的 Google Cloud 帐号。如果您是 Google Cloud 新手,请创建一个帐号来评估我们的产品在实际场景中的表现。新客户还可获享 $300 赠金,用于运行、测试和部署工作负载。
-
在 Google Cloud Console 中的项目选择器页面上,选择或创建一个 Google Cloud 项目。
-
确保您的 Google Cloud 项目已启用结算功能。了解如何检查项目是否已启用结算功能。
- 安装 Google Cloud CLI。
-
如需初始化 gcloud CLI,请运行以下命令:
gcloud init
-
在 Google Cloud Console 中的项目选择器页面上,选择或创建一个 Google Cloud 项目。
-
确保您的 Google Cloud 项目已启用结算功能。了解如何检查项目是否已启用结算功能。
- 安装 Google Cloud CLI。
-
如需初始化 gcloud CLI,请运行以下命令:
gcloud init
编写示例作业
如需在 Go 中编写作业,请执行以下操作:
创建名为
jobs
的新目录,并转到此目录中:mkdir jobs cd jobs
在同一目录中,为实际作业代码创建一个
main.go
文件。将以下示例行复制到其中:Cloud Run 作业允许用户指定作业要执行的任务数量。此示例代码演示了如何使用内置
CLOUD_RUN_TASK_INDEX
环境变量。每个任务代表容器的一个正在运行的副本。 请注意,任务通常并行执行。如果每个任务都可以独立处理一部分数据,则使用多个任务非常有用。每个任务都知道其存储在
CLOUD_RUN_TASK_INDEX
环境变量中的索引。内置CLOUD_RUN_TASK_COUNT
环境变量包含在执行作业时通过--tasks
参数提供的任务数量。此处所示的代码还展示了如何使用内置
CLOUD_RUN_TASK_ATTEMPT
环境变量重试任务,该变量包含此任务重试的次数,从 0 开始(表示第一次尝试),然后每次连续重试时递增 1,上限为--max-retries
。此外,通过代码,您还可以生成失败来测试重试并生成错误日志,从而查看失败情况。
创建一个包含以下内容的
go.mod
文件:
您的代码已完成,可以封装在容器中。
构建作业容器并发送到代码库
重要提示:本快速入门假定您在快速入门中使用的项目中拥有所有者或编辑者角色。否则,请参阅 Cloud Run 部署权限、Cloud Build 权限和 Artifact Registry 权限,获取需要的权限。
使用 buildpack 构建容器:gcloud builds submit --pack image=gcr.io/PROJECT_ID/logger-job
在 Cloud Run 中创建作业
如需使用您刚刚构建的容器创建作业,请运行以下命令:
gcloud run jobs create job-quickstart \ --image gcr.io/PROJECT_ID/logger-job \ --tasks 50 \ --set-env-vars SLEEP_MS=10000 \ --set-env-vars FAIL_RATE=0.5 \ --max-retries 5 \ --region REGION --project=PROJECT_ID
其中,PROJECT_ID 是您的项目 ID,REGION 是您的区域,例如 us-central1
。请注意,您可以将各种参数更改为要用于测试的任何值。SLEEP_MS
模拟工作,FAIL_RATE
导致 X
% 的任务失败,因此您可以试验并行情况并重试失败任务。
在 Cloud Run 中执行作业
如需执行刚刚创建的作业,请运行以下命令:
gcloud run jobs execute job-quickstart
当系统提示您输入区域时:请选择您选择的区域,例如 us-central1
。
在本地测试
您可以在本地运行作业:
docker run --rm -e FAIL_RATE=0.9 -e SLEEP_MS=1000 gcr.io/PROJECT_ID/logger-job其中,PROJECT_ID 是您的项目 ID。
后续步骤
如需详细了解如何使用代码源构建容器并推送到代码库,请参阅: