为 Compute Engine 启用 IAP

本页介绍如何使用 Identity-Aware Proxy (IAP) 保护 Compute Engine 实例。

准备工作

要为 Compute Engine 启用 IAP,您需要以下各项:

如果您尚未设置 Compute Engine 实例,请参阅为 Compute Engine 设置 IAP 以查看完整演示。

使用 Cloud Console 启用 IAP

配置 OAuth 同意屏幕

如果您尚未配置项目的 OAuth 同意屏幕,则需要执行此操作。您必须配置 OAuth 同意屏幕上的电子邮件地址和产品名称。

  1. 转到 OAuth 同意屏幕
    配置同意屏幕
  2. 支持电子邮件地址下,选择要显示为公开联系人的电子邮件地址。该电子邮件地址必须是您自己的电子邮件地址或您拥有的某一 Google 群组的电子邮件地址。
  3. 输入您要显示的应用名称
  4. 根据需要添加任何可选详细信息。
  5. 点击保存

如需稍后更改 OAuth 同意屏幕上的信息(例如产品名称或电子邮件地址),请重复上述步骤配置同意屏幕。

创建 OAuth 凭据

  1. 转到“凭据”页面
    转到“凭据”页面
  2. 创建凭据下拉列表中,选择 OAuth 客户端 ID
  3. 应用类型下,选择网页应用
  4. 为您的 OAuth 客户端 ID 添加一个名称
  5. 点击创建。您的 OAuth 客户端 ID 和客户端密钥已生成,并显示在 OAuth 客户端窗口中。
  6. 点击确定
  7. 选择您创建的客户端。
  8. 将客户端 ID 复制到剪贴板。
  9. 按照以下格式将通用重定向网址添加到已获授权的重定向 URI 字段中:
    https://iap.googleapis.com/v1/oauth/clientIds/CLIENT_ID:handleRedirect

    其中,CLIENT_ID 是 OAuth 客户端 ID。

  10. 在页面顶部附近,点击下载 JSON。下一步骤将会用到这些凭据。

设置 IAP 访问权限

  1. 转到 Identity-Aware Proxy 页面
    转到 Identity-Aware Proxy 页面
  2. 选择要使用 IAP 保护的项目。
  3. 选中您要授予访问权限的资源旁边的复选框。
  4. 在右侧面板上,点击添加主帐号
  5. 在显示的添加主帐号对话框中,输入群组或个人(应拥有项目的 IAP-secured Web App User 角色)的电子邮件地址。

    以下种类的主帐号可以具有此角色:

    • Google 帐号:user@gmail.com
    • Google 网站论坛:admins@googlegroups.com
    • 服务帐号:server@example.gserviceaccount.com
    • Google Workspace 网域:example.com

    请务必添加您有权访问的 Google 帐号。

  6. 角色下拉列表中选择 Cloud IAP > 受 IAP 保护的网页应用用户
  7. 点击保存

启用 IAP

  1. Identity-Aware Proxy 页上的 HTTPS 资源下,找到用于处理要限制访问的 instance group 的负载平衡器。如需为某资源开启 IAP,请
    如需启用 IAP,需要满足以下条件:
    • 负载平衡器前端配置中至少一个协议必须是 HTTPS。了解设置负载平衡器
    • 您需要 compute.backendServices.updateclientauthconfig.clients.createclientauthconfig.clients.getWithSecret 权限。这些权限由 Project Editor 等角色授予。如需了解详情,请参阅管理对受 IAP 保护的资源的访问权限
  2. 在出现的开启 IAP 窗口中,点击开启以确认您想用 IAP 保护资源。开启 IAP 后,它需要向对负载平衡器的所有连接请求索要登录凭据。只有具有项目的 IAP-Secured Web App User 角色的帐号才能获得访问权限。

使用 Cloud SDK 启用 IAP

本节介绍如何使用 gcloud 命令行工具为 Compute Engine 应用开启 IAP。尚不支持使用 gcloud 命令行工具为 App Engine 开启 IAP。若要执行此操作,请参阅 App Engine 快速入门

获取 Cloud SDK

在设置项目和 IAP 之前,您需要最新版本的 Cloud SDK。获取 Cloud SDK

设置项目

选择要为其启用 IAP 的项目,然后按如下所示进行设置:

  1. 转到“实例组”页面,以确保您的实例包含在实例组中。
  2. 定义后端服务。
  3. 设置外部内部负载平衡。
  4. 设置 OAuth 客户端:
    1. 依次转到 API > 凭据,然后选择要为其启用 IAP 的项目。
    2. 设置 OAuth 同意屏幕
      1. 转到 OAuth 同意屏幕
        配置同意屏幕
      2. 支持电子邮件地址下,选择要显示为公开联系人的电子邮件地址。该电子邮件地址必须是您自己的电子邮件地址或您拥有的某一 Google 群组的电子邮件地址。
      3. 输入您要显示的应用名称
      4. 根据需要添加任何可选详细信息。
      5. 点击保存

      如需稍后更改 OAuth 同意屏幕上的信息(例如产品名称或电子邮件地址),请重复上述步骤配置同意屏幕。

    3. 凭据下,点击创建凭据 > OAuth 客户端 ID
    4. 应用类型下,选择 Web 应用,然后添加名称
    5. 输入完详细信息后,点击创建
    6. 在显示的 OAuth 客户端窗口中,记下客户端 ID客户端密钥
    7. 再次选择该客户端。按照 https://iap.googleapis.com/v1/oauth/clientIds/CLIENT_ID:handleRedirect 格式将通用重定向网址添加到已获授权的重定向 URI 字段,其中 CLIENT_ID 是 OAuth 客户端 ID。

启用 IAP

  1. 使用 gcloud 命令行工具运行 gcloud auth login
  2. 按照显示的网址登录。
  3. 登录后,复制显示的验证码并将其粘贴到命令行中。
  4. 对要为其启用 IAP 的项目运行 gcloud config set project PROJECT_ID
  5. 如需启用 IAP,请使用您之前创建的 OAuth 客户端 ID 和密钥并运行全局范围或区域级命令。
    • 全局范围:gcloud compute backend-services update BACKEND_SERVICE_NAME --global --iap=enabled,oauth2-client-id=CLIENT_ID,oauth2-client-secret=CLIENT_SECRET
    • 区域范围:gcloud compute backend-services update BACKEND_SERVICE_NAME --regional REGION_NAME --iap=enabled,oauth2-client-id=CLIENT_ID,oauth2-client-secret=CLIENT_SECRET

启用 IAP 后,您可以使用 gcloud 命令行工具并通过 IAM 角色 roles/iap.httpsResourceAccessor 操纵 IAP 访问权限政策。详细了解如何管理角色和权限