为 Cloud Workstations 设置自定义网域

如需访问工作站,您可以指定可信的自定义网域,而不是使用 cloudworkstations.dev 网域。

架构

如需将 Cloud Workstations 与自定义主机名搭配使用,请设置专用集群,并为专用集群设置 Private Service Connect (PSC) 端点以实现 HTTP Ingress。您还必须创建一个具有 PSC 后端的应用负载平衡器,该后端以为您的专用集群创建的 PSC 端点作为目标。此应用负载平衡器可以是外部的,也可以是内部的,用于管理自定义网域的 SSL 证书。

下图展示了具有自定义网域的集群:

图 1. 使用自定义网域的集群

准备工作

如需设置 Cloud Workstations 自定义网域,请按以下步骤操作:

  1. 创建专用集群,并使用 gcloud CLI 或 REST API 命令指定可信的自定义网域。

  2. 在您用于工作站集群项目的同一项目中,使用 Private Service Connect (PSC) 后端创建全球外部应用负载平衡器。请注意以下几点:

    1. 如果您希望将工作站设为专用工作站(无法通过公共互联网访问),请务必创建内部负载均衡器。为此,请创建一个专用 DNS 区域,并添加一条记录,将网域映射到负载均衡器使用的内部 IP 地址。如需详细了解如何创建内部负载均衡器,请参阅 VPC 文档

    2. 创建集群后,您可以从工作站集群资源上获取需要在负载均衡器中引用的服务连接。

    3. 请确保您已获取证书,并在负载平衡器上将其指定为网域的通配符证书(例如 *.us-west1-cluster1.example.com)。如需了解您选择的负载均衡器支持的证书类型,请参阅证书和 Google Cloud 负载均衡器

    4. 您也可以在其他项目中创建负载均衡器,只要将其添加到 PrivateClusterConfig.allowedProjects 列表中即可。

    5. 如果您的组织中有多个工作站集群,则可以将单个负载均衡器与单独的后端服务、证书和路由规则结合使用。

  3. 设置域名系统 (DNS)。由于这是您管理的网域,因此,您可以将提供网域的所有子网域映射到负载均衡器,从而为此网域设置 DNS。例如,为 us-west1-cluster1.example.com 创建 DNS 区域,并添加一个将 *.us-west1-cluster1.example.com 映射到您的负载均衡器使用的外部 IP 地址的条目。

  4. 如需使用自定义网域访问工作站,请使用您创建的集群创建工作站配置,然后使用该工作站配置创建工作站

  5. 启动工作站并检查网址。指定自定义网域时,工作站网址采用以下格式:

    https://PORT-WORKSTATION_NAME.DOMAIN
    

    网址的以下部分取决于您的配置:

    • PORT:端口号,默认为端口 80
    • WORKSTATION_NAME:您的工作站名称。
    • DOMAIN:您的集群专用域名

Create a private cluster(创建专用集群)

创建具有专用端点的专用工作站集群:

gcloud

  1. 在开始之前,请确保您已运行 gcloud init初始化 gcloud CLI,并且指定了默认项目。以下示例假定您已设置默认项目。

  2. 如需创建专用工作站集群,请运行以下命令:

    gcloud workstations clusters create WORKSTATION_CLUSTER \
      --region=REGION \
      --domain=DOMAIN \
      --enable-private-endpoint
    

    替换以下内容:

    • WORKSTATION_CLUSTER:要创建的工作站集群的名称。
    • REGION:集群区域的名称。
    • DOMAIN:Cloud Workstations 用于 HTTP Ingress 的域名。使用此集群独有的子网域,例如 us-west1-cluster1.example.com

如需详细了解此 gcloud CLI 命令,请参阅 gcloud workstations clusters create 参考文档。

curl

curl -H "Authorization: Bearer $(gcloud auth print-access-token)" -H "Content-Type: application/json"  -d '{"domain_config": {"domain": "DOMAIN"}, "private_cluster_config":{"enable_private_endpoint":true}}'  https://workstations.googleapis.com/v1/projects/PROJECT_NAME/locations/REGION/workstationClusters?workstation_cluster_id=WORKSTATION_CLUSTER

替换以下内容:

  • DOMAIN:Cloud Workstations 用于 HTTP Ingress 的域名。这应该是此集群独有的子网域,例如 us-west1-cluster1.example.com
  • PROJECT_NAME:项目的名称。
  • REGION:集群区域的名称。
  • WORKSTATION_CLUSTER:要创建的工作站集群的名称。

如需详细了解此 API 方法,请参阅 workstationClusters.create 参考文档。

REST

POST https://workstations.googleapis.com/v1/projects/PROJECT_NAME/locations/REGION/workstationClusters?workstationClusterId=WORKSTATION_CLUSTER
{
  "domainConfig": {
    "domain": "DOMAIN"
  },
  "privateClusterConfig": {
    "enablePrivateEndpoint": true
  }
}

替换以下内容:

  • PROJECT_NAME:项目的名称。
  • REGION:集群区域的名称。
  • WORKSTATION_CLUSTER:要创建的工作站集群的名称。
  • DOMAIN:Cloud Workstations 用于 HTTP Ingress 的域名。这应该是此集群独有的子网域,例如 us-west1-cluster1.example.com

如需详细了解此 API 方法,请参阅 workstationClusters.create 参考文档。

使用 PSC 后端创建全局外部应用负载平衡器

执行以下 gcloud CLI 和 REST API 步骤,创建具有 PSC 后端的全球外部应用负载平衡器:

  1. 创建 NEG 以连接到已发布的服务
  2. 将后端添加到全局外部应用负载平衡器
  3. 创建网址映射以将传入的请求路由到后端服务
  4. 创建目标 HTTPS 代理
  5. 创建全局地址
  6. 创建转发规则

创建 NEG 以连接到已发布的服务

创建指向已发布服务的 NEG 时,您需要该服务的服务连接 URI。服务连接采用以下格式:projects/SERVICE_PROJECT/regions/REGION/serviceAttachments/SERVICE_NAME。您可以在工作站集群资源上找到该 URI。

gcloud

gcloud compute network-endpoint-groups create NEG_NAME \
  --network-endpoint-type=private-service-connect \
  --psc-target-service=TARGET_SERVICE \
  --region=REGION \
  --network=NETWORK \
  --subnet=SUBNET

替换以下内容:

  • NEG_NAME:网络端点组的名称。
  • TARGET_SERVICE:服务连接的 URI。
  • REGION:要在其中创建网络端点组的区域。该区域必须与目标服务的区域相同。
  • NETWORK:要在其中创建网络端点组的网络。如果省略,则使用默认网络。
  • SUBNET:要在其中创建网络端点组的子网。子网必须与目标服务位于同一区域。如果您提供网络,则必须提供子网。如果同时省略网络和子网,系统会使用默认网络,并使用指定 REGION 中的默认子网。

如需详细了解此 gcloud CLI 命令,请参阅 gcloud compute network-endpoint-groups create 参考文档。

REST

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/regions/REGION/networkEndpointGroups
{
  "pscTargetService": "TARGET_SERVICE",
  "networkEndpointType": "PRIVATE_SERVICE_CONNECT",
  "name": "NEG_NAME"
}

替换以下内容:

  • PROJECT_NAME:项目的名称。
  • REGION:要在其中创建网络端点组的区域。该区域必须与目标服务的区域相同。
  • NEG_NAME:网络端点组的名称。
  • TARGET_SERVICE:服务连接的 URI。

向全局外部应用负载平衡器添加后端

gcloud

  1. 为目标服务创建后端服务:

    gcloud compute backend-services create BACKEND_SERVICE_NAME \
    --load-balancing-scheme=EXTERNAL_MANAGED \
    --protocol=HTTPS \
    --global
    

    BACKEND_SERVICE_NAME 替换为后端服务的名称。

  2. 添加指向目标服务的 Private Service Connect NEG。

    gcloud compute backend-services add-backend BACKEND_SERVICE_NAME \
    --network-endpoint-group=NEG_NAME \
    --network-endpoint-group-region=NEG_REGION \
    --global
    

    替换以下内容:

    • BACKEND_SERVICE_NAME:后端服务的名称。
    • NEG_NAME:网络端点组的名称。
    • NEG_REGION:网络端点组的区域。

如需详细了解此 gcloud CLI 命令,请参阅 gcloud compute backend-services creategcloud compute backend-services add-backend 参考文档。

REST

  1. 为目标服务创建后端服务:

    POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/backendServices
    {
      "protocol": "HTTPS",
      "loadBalancingScheme": "EXTERNAL_MANAGED",
      "name": "BACKEND_SERVICE_NAME"
    }
    

    BACKEND_SERVICE_NAME 替换为后端服务的名称。

  2. 添加指向目标服务的 Private Service Connect NEG。

    PATCH https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/backendServices/BACKEND_SERVICE_NAME
    {
      "backends": [
        {
          "group": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/regions/NEG_REGION/networkEndpointGroups/NEG_NAME "
        }
      ]
    }
    

    替换以下内容:

    • PROJECT_NAME:项目的名称。
    • BACKEND_SERVICE_NAME:后端服务的名称。
    • NEG_REGION:网络端点组的区域。
    • NEG_NAME:网络端点组的名称。

创建网址映射,将传入的请求路由到后端服务

gcloud

gcloud compute url-maps create URL_MAP_NAME \
  --default-service=BACKEND_SERVICE_NAME \
  --global

替换以下内容:

  • URL_MAP_NAME:要创建的网址映射的名称。
  • BACKEND_SERVICE_NAME:此网址映射没有映射时,用于请求的后端服务的名称。

如需详细了解此 gcloud CLI 命令,请参阅 gcloud compute url-maps create 参考文档。

REST

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/urlMaps
{
  "name": "URL_MAP_NAME",
  "defaultService": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/backendServices/BACKEND_SERVICE_NAME "
}

替换以下内容:

  • PROJECT_NAME:项目的名称。
  • URL_MAP_NAME:要创建的网址映射的名称。
  • BACKEND_SERVICE_NAME:此网址映射没有映射时,用于请求的后端服务的名称。

创建目标 HTTPS 代理

创建目标 HTTPS 代理以将请求路由到您的网址映射。该代理属于负载均衡器的一部分,保存用于 HTTPS 负载均衡的 SSL 证书,因此您还需要在此步骤中加载证书:

gcloud

gcloud compute target-https-proxies create TARGET_HTTPS_PROXY_NAME \
  --ssl-certificates=SSL_CERTIFICATE_NAME \
  --url-map=URL_MAP_NAME \
  --global

替换以下内容:

  • TARGET_HTTPS_PROXY_NAME:要创建的目标 HTTPS 代理的名称。
  • SSL_CERTIFICATE_NAME:与负载均衡器关联的 SSL 证书。
  • URL_MAP_NAME:网址映射资源。

如需详细了解此 gcloud CLI 命令,请参阅 gcloud compute target-https-proxies create 参考文档。

REST

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/targetHttpsProxies
{
  "sslCertificates": [
    "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/sslCertificates/SSL_CERTIFICATE_NAME"
  ],
  "urlMap": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/urlMaps/URL_MAP_NAME",
  "name": "TARGET_HTTPS_PROXY_NAME"
}

替换以下内容:

  • PROJECT_NAME:项目的名称。
  • SSL_CERTIFICATE_NAME:与负载均衡器关联的 SSL 证书。
  • URL_MAP_NAME:网址映射资源。
  • TARGET_HTTPS_PROXY_NAME:要创建的目标 HTTPS 代理的名称。

创建全局地址

预留供负载均衡器使用的静态 IP 地址:

gcloud

gcloud compute addresses create LB_IP_ADDRESS_NAME \
  --global

替换以下内容:

  • LB_IP_ADDRESS_NAME:为负载均衡器预留的静态外部或内部 IP 地址的名称。

如需详细了解此 gcloud CLI 命令,请参阅 gcloud compute addresses create 参考文档。

REST

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/addresses
{
  "name": "LB_IP_ADDRESS_NAME"
}

替换以下内容:

  • PROJECT_NAME:项目的名称。
  • LB_IP_ADDRESS_NAME:为负载均衡器预留的静态外部或内部 IP 地址的名称。

创建转发规则

创建转发规则以将传入请求路由到相应代理:

gcloud

gcloud compute forwarding-rules create HTTPS_FORWARDING_RULE_NAME \
  --load-balancing-scheme=EXTERNAL_MANAGED \
  --network-tier=PREMIUM \
  --address=LB_IP_ADDRESS_NAME  \
  --target-https-proxy=TARGET_HTTPS_PROXY_NAME  \
  --global \
  --ports=443

替换以下内容:

  • HTTPS_FORWARDING_RULE_NAME:要创建的转发规则的名称。
  • LB_IP_ADDRESS_NAME:为负载均衡器预留的静态外部或内部 IP 地址的名称。
  • TARGET_HTTPS_PROXY_NAME:接收流量的目标 HTTPS 代理。

如需详细了解此 gcloud CLI 命令,请参阅 gcloud compute forwarding-rules create 参考文档。

REST

POST https://compute.googleapis.com/compute/v1/projects/PROJECT_NAME/global/forwardingRules
{
  "loadBalancingScheme": "EXTERNAL_MANAGED",
  "networkTier": "PREMIUM",
  "IPAddress": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/addresses/LB_IP_ADDRESS_NAME",
  "target": "https://www.googleapis.com/compute/v1/projects/PROJECT_NAME/global/targetHttpsProxies/TARGET_HTTPS_PROXY_NAME",
  "name": "HTTPS_FORWARDING_RULE_NAME",
  "portRange": "443-443"
}

替换以下内容:

  • PROJECT_NAME:项目的名称。
  • LB_IP_ADDRESS_NAME:为负载均衡器预留的静态外部或内部 IP 地址的名称。
  • TARGET_HTTPS_PROXY_NAME:接收流量的目标 HTTPS 代理。
  • HTTPS_FORWARDING_RULE_NAME:要创建的转发规则的名称。

设置 DNS

设置 DNS 并添加一条记录,用于将 *.DOMAIN(例如 *.example.com)映射到上一步中预留的 IP 地址。如果您要使用 Cloud DNS 管理网域的 DNS,请参阅添加 DNS 记录

创建工作站配置和工作站

如需使用自定义网域访问工作站,请执行以下操作:

  1. 使用具有自定义网域的集群创建工作站配置

  2. 使用带有自定义网域的工作站配置创建工作站

后续步骤

如需详细了解如何设置自定义网域和专用集群,请参阅以下内容: