使用 VPC Service Controls 保护 Cron 作业

VPC Service Controls 是 Google Cloud 的一项功能,可让您设置安全的边界以防数据渗漏。 本指南介绍了如何在 VPC Service Controls 边界中添加 Cloud Scheduler 作业。

限制

VPC Service Controls 对 Cloud Scheduler 的支持存在以下限制。

强制执行的操作

系统仅针对以下操作强制执行 VPC Service Controls:

  • Cloud Scheduler 作业创建
  • Cloud Scheduler 作业更新

这一点为什么非常重要?

由于 VPC Service Controls 仅在创建作业和更新作业时强制执行,因此在您将 Cloud Scheduler 添加到 VPC Service Controls 边界之前创建的作业不会自动强制执行 VPC Service Controls。即使作业目标不在您的 VPC Service Controls 边界内或不是受支持的目标,作业也会继续执行。接收者 对所有 Cloud Scheduler 作业强制执行 VPC Service Controls:

支持的目标

Cloud Scheduler 与 VPC Service Controls 的集成仅支持以下目标:

  • Cloud Run 函数(位于 functions.net 网址中)
  • Cloud Run(在 Cloud Run 服务的 run.app 网址上)。不支持 Cloud Run 作业目标。学习内容 服务和作业资源之间的区别 Cloud Run,请参阅 服务和作业:运行代码的两种方法。)
  • Dataflow API(必须与 Cloud Scheduler 作业)
  • Data Pipelines(必须与 Cloud Scheduler 作业位于同一 Google Cloud 项目中)
  • Pub/Sub(必须与 Cloud Scheduler 作业位于同一 Google Cloud 项目中)

删除不合规的作业

推荐。删除目标属于以下情况的 Cloud Scheduler 作业:

有关删除作业的说明,请参阅 删除作业

如果您未在将 Cloud Scheduler 添加到 VPC Service Controls 边界之前删除这些作业,这些作业会继续运行,但不会受到 VPC Service Controls 强制执行的约束(请参阅强制执行的操作)。

例如,假设您有一个 Cloud Scheduler 作业,该作业针对 不受支持的目标(例如 Cloud Run 自定义网域),则 将 Cloud Scheduler 添加到 VPC Service Controls 边界,但它不受 VPC Service Controls 保护。通过 对于既有职位,但职位并非 VPC Service Controls 边界。

添加所需的 IAM 角色

必需。如需使用 VPC Service Controls,Cloud Scheduler 服务账号必须具有 Cloud Scheduler Service Agent IAM 角色。系统会自动为您的项目创建 Cloud Scheduler 服务账号。如需验证该服务账号是否具有 Cloud Scheduler 服务代理 IAM 角色,或授予此角色,请执行以下步骤:

  1. 在 Google Cloud 控制台中,浏览到 IAM

    转到 IAM

  2. 选中包括 Google 提供的角色授权复选框。

  3. 在过滤器中,输入 Cloud Scheduler Service Account,然后选择 主账号。

  4. 查看 Cloud Scheduler 服务账号角色列 主账号。如果系统列出了以下角色,您可以继续执行操作:

    • Cloud Scheduler Service Agent

    如果未列出 Cloud Scheduler 服务账号角色,请点击 修改图标,并将 Cloud Scheduler Service Agent 角色授予 Cloud Scheduler 服务账号主账号。

指定 VPC Service Controls 边界

必需。您可以使用现有边界,也可以创建新边界 支持的 Cloud Scheduler 作业, 目标。您可以通过这两种方法指定要限制的服务。指定 Cloud Scheduler API

  • 现有边界:用于更新现有的 VPC Service Controls 边界 添加 Cloud Scheduler 更新服务边界

  • 新边界:如需为 Cloud Scheduler 创建新的边界,请按照创建服务边界中的步骤操作。

对现有作业强制执行 VPC Service Controls

推荐。如需对您在将 Cloud Scheduler 添加到 VPC Service Controls 边界之前创建的 Cloud Scheduler 作业强制执行 VPC Service Controls,请对作业运行 update。您不必 但您必须运行更新,VPC Service Controls 应用于作业及其未来的执行。

您可以从 Google Cloud 控制台(选择 作业并使用修改按钮)、使用 API 或 gcloud CLI。

要使用 VPC Service Controls gcloud CLI,请运行以下命令:

HTTP 目标

gcloud scheduler jobs update http JOB_ID

替换以下内容:

  • JOB_ID:作业的 ID

Pub/Sub 目标

gcloud scheduler jobs update pubsub JOB_ID

替换以下内容:

  • JOB_ID:作业的 ID