使用 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 添加到边界后,对每个作业运行更新。请参阅对现有作业强制执行

支持的目标

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

  • Cloud Run functions(在 functions.net 网址上)
  • Cloud Run(在 Cloud Run 服务的 run.app 网址上)。不支持 Cloud Run 作业目标。如需了解 Cloud Run 的服务资源和作业资源之间的区别,请参阅服务和作业:运行代码的两种方式。)
  • Dataflow API(必须与 Cloud Scheduler 作业位于同一 Google Cloud 项目中)
  • 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 服务账号,然后选择此正文。

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

    • Cloud Scheduler Service Agent

    如果未列出 Cloud Scheduler 服务账号角色,请点击修改图标,然后向 Cloud Scheduler 服务账号正文授予 Cloud Scheduler Service Agent 角色。

指定 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 为作业运行更新。

如需使用 gcloud CLI 对现有作业强制执行 VPC Service Controls,请运行以下命令:

HTTP 目标

gcloud scheduler jobs update http JOB_ID

替换以下内容:

  • JOB_ID:作业的 ID

Pub/Sub 目标

gcloud scheduler jobs update pubsub JOB_ID

替换以下内容:

  • JOB_ID:作业的 ID