设置容器实例数量上限

了解如何设置可用于 Cloud Run for Anthos on Google Cloud 服务的容器实例数上限。通过在 Cloud Run for Anthos 中指定实例数量上限,您可以限制服务响应传入请求的扩缩范围。使用此设置可以控制您的费用或限制与备份服务(如数据库)的连接数。

如需详细了解 Cloud Run for Anthos 自动扩缩容器实例的方式,请参阅实例自动扩缩

设置和更新实例数量上限

任何配置更改都会导致新修订版本的创建。后续修订版本也将自动采用此配置设置,除非您进行了明确更新。

默认情况下,容器实例数量可以无限扩容。在部署新服务或更新现有服务和部署修订版本时,您可以使用 Cloud Console 或 gcloud 命令行工具设置实例数上限:

控制台

  1. 转到 Cloud Run for Anthos on Google Cloud

  2. 如果您是要配置一个新服务来作为部署目标,请点击创建服务。如果您要配置现有服务,请点击该服务,然后点击修改和部署新的修订版本

  3. 在“高级设置”下,点击容器

    图片

  4. “实例数上限”字段中,指定所需的容器实例数上限。

  5. 点击创建部署

命令行

  • 对于现有服务,请运行带有 --max-instances 参数的 gcloud kuberun core services update 命令来设置容器实例数上限

    gcloud kuberun core services update SERVICE --max-instances MAX-VALUE
    

    您需要将其中的:

    • SERVICE 替换为您的服务名称。
    • MAX-VALUE 替换为所需的容器实例数上限。指定 default 即可清除所有实例上限设置。
  • 对于新服务,请运行带有 --max-instances 参数的 gcloud kuberun core services create 命令来设置容器实例数上限:

    gcloud kuberun core services create SERVICE --image=IMAGE_URL --max-instances MAX-VALUE
    

    您需要将其中的:

    • SERVICE 替换为您的服务名称。
    • IMAGE_URL 替换为对容器映像的引用,例如 gcr.io/myproject/my-image:latest
    • MAX-VALUE 替换为所需的容器实例数上限。指定 default 即可清除所有实例上限设置。

YAML

如需使用 YAML 文件修改现有服务的配置,请获取当前配置的副本,修改相应配置并将更改保存到本地文件内,然后再将这些更改部署到服务中。

  1. 显示为 YAML,然后将服务的配置复制到本地文件(例如 service.yaml)中:

    gcloud kuberun core services describe SERVICE --format yaml

    SERVICE 替换为您的 Cloud Run for Anthos 服务的名称。

  2. 在本地文件中,更新 autoscaling.knative.dev/maxScale: 属性:

    spec:
     template:
       metadata:
         annotations:
           autoscaling.knative.dev/maxScale: 'MAX-INSTANCE' 

    替换

    • MAX-INSTANCE 替换为所需的数量上限。
  3. 使用以下命令将服务替换为其新配置:

    gcloud beta run services replace service.yaml