本页介绍如何使用 Identity-Aware Proxy (IAP) 保护 Compute Engine 实例。
准备工作
要为 Compute Engine 启用 IAP,您需要以下各项:
- 启用了结算功能的 Cloud Console 项目。
- 由负载平衡器提供服务的一个或多个 Compute Engine 实例。
- 了解如何设置外部 HTTPS 负载平衡器。
- 了解如何设置内部 HTTP 负载平衡器。
- 已注册到负载平衡器地址的域名。
- 用于验证所有请求都拥有一个身份的应用代码。
- 了解如何获取用户的身份。
如果您尚未设置 Compute Engine 实例,请参阅为 Compute Engine 设置 IAP 以查看完整演示。
使用 Cloud Console 启用 IAP
配置 OAuth 同意屏幕
如果您尚未配置项目的 OAuth 同意屏幕,则需要执行此操作。您必须配置 OAuth 同意屏幕上的电子邮件地址和产品名称。
-
转到 OAuth 同意屏幕。
配置同意屏幕 - 在支持电子邮件地址下,选择要显示为公开联系人的电子邮件地址。该电子邮件地址必须是您自己的电子邮件地址或您拥有的某一 Google 群组的电子邮件地址。
- 输入您要显示的应用名称。
- 根据需要添加任何可选详细信息。
- 点击保存。
如需稍后更改 OAuth 同意屏幕上的信息(例如产品名称或电子邮件地址),请重复上述步骤配置同意屏幕。
创建 OAuth 凭据
-
转到“凭据”页面。
转到“凭据”页面 - 在创建凭据下拉列表中,选择 OAuth 客户端 ID。
- 在应用类型下,选择网页应用。
- 为您的 OAuth 客户端 ID 添加一个名称。
- 点击创建。您的 OAuth 客户端 ID 和客户端密钥已生成,并显示在 OAuth 客户端窗口中。
- 点击确定。
- 选择您创建的客户端。
- 将客户端 ID 复制到剪贴板。
- 按照以下格式将通用重定向网址添加到已获授权的重定向 URI 字段中:
https://iap.googleapis.com/v1/oauth/clientIds/CLIENT_ID:handleRedirect
其中,
CLIENT_ID
是 OAuth 客户端 ID。 - 在页面顶部附近,点击下载 JSON。下一步骤将会用到这些凭据。
设置 IAP 访问权限
-
转到 Identity-Aware Proxy 页面。
转到 Identity-Aware Proxy 页面 - 选择要使用 IAP 保护的项目。
- 选中您要向其添加成员的资源旁边的复选框。
- 在右侧面板上,点击添加成员。
- 在显示的添加成员对话框中,输入群组或个人(应拥有项目的受 IAP 保护的网页应用用户角色)的电子邮件地址。
可以添加以下种类的帐号作为成员:
- Google 帐号:user@gmail.com
- Google 群组:<管理员>@googlegroups.com
- 服务帐号:<服务器>@<示例>.gserviceaccount.com
- Google Workspace 网域:example.com
请务必添加您有权访问的 Google 帐号。
- 从角色下拉列表中选择 Cloud IAP > 受 IAP 保护的网页应用用户。
- 点击保存。
启用 IAP
-
在 Identity-Aware Proxy 页上的 HTTPS 资源下,找到用于处理要限制访问的 instance group 的负载平衡器。如需为某资源开启 IAP,请
如需启用 IAP,需要满足以下条件:- 负载平衡器前端配置中至少一个协议必须是 HTTPS。了解设置负载平衡器。
-
您需要
compute.backendServices.update
、clientauthconfig.clients.create
和clientauthconfig.clients.getWithSecret
权限。这些权限由 Project Editor 等角色授予。如需了解详情,请参阅管理对受 IAP 保护的资源的访问权限。
- 在出现的开启 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 的项目,然后按如下所示进行设置:
- 转到“实例组”页面,以确保您的实例包含在实例组中。
- 定义后端服务。
- 设置外部或内部负载平衡。
- 设置 OAuth 客户端:
- 依次转到 API > 凭据,然后选择要为其启用 IAP 的项目。
-
设置 OAuth 同意屏幕:
-
转到 OAuth 同意屏幕。
配置同意屏幕 - 在支持电子邮件地址下,选择要显示为公开联系人的电子邮件地址。该电子邮件地址必须是您自己的电子邮件地址或您拥有的某一 Google 群组的电子邮件地址。
- 输入您要显示的应用名称。
- 根据需要添加任何可选详细信息。
- 点击保存。
如需稍后更改 OAuth 同意屏幕上的信息(例如产品名称或电子邮件地址),请重复上述步骤配置同意屏幕。
-
转到 OAuth 同意屏幕。
- 在凭据下,点击创建凭据 > OAuth 客户端 ID。
- 在应用类型下,选择 Web 应用,然后添加名称。
- 输入完详细信息后,点击创建。
- 在显示的 OAuth 客户端窗口中,记下客户端 ID 和客户端密钥。
-
再次选择该客户端。按照
https://iap.googleapis.com/v1/oauth/clientIds/CLIENT_ID:handleRedirect
格式将通用重定向网址添加到已获授权的重定向 URI 字段,其中 CLIENT_ID 是 OAuth 客户端 ID。
启用 IAP
- 使用
gcloud
命令行工具运行gcloud auth login
。 - 按照显示的网址登录。
- 登录后,复制显示的验证码并将其粘贴到命令行中。
-
对要为其启用 IAP 的项目运行
gcloud config set project PROJECT_ID
。 -
如需启用 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 访问权限政策。详细了解如何管理角色和权限。