配置内存限制

本页面介绍如何设置内存限制。

了解内存用量

如果 Cloud Run 容器实例超出其允许的内存限制,则该应用会被终止。

以下各项会计入容器实例的可用内存:

  • 运行应用可执行文件(当可执行文件必须加载到内存中时)
  • 在应用进程中分配内存
  • 将文件写入文件系统

部署的容器映像的大小不会计入可用内存。

设置和更新内存限制

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

默认情况下,系统会为一个修订版本的每个容器实例分配 256MiB 内存。

vCPU 必须大于 2 个,才能设置大于 4GiB 的内存上限。

您可以在创建新服务部署新修订版本时使用 Cloud Console、gcloud 命令行或 YAML 文件设置内存限制:

控制台

  1. 转到 Cloud Run

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

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

    图片

  4. 分配的内存下拉列表中选择所需的内存大小。

  5. 点击创建部署

命令行

您可以使用以下命令更新给定服务的内存分配

gcloud run services update SERVICE --memory SIZE

SERVICE 替换为您的服务名称,并将 SIZE 替换为所需的内存大小。内存大小可以表示为定点数或浮点数后接 GMK 单位的形式(这些单位分别代表千兆字节、兆字节、千字节),也可以表示为等效的 2 的幂次方数(即 GiMiKi,这些单位分别代表吉比字节、兆比字节、千字节)。

您还可以在部署期间使用以下命令设置内存限制:

gcloud run deploy --image IMAGE_URL --memory SIZE

替换

  • IMAGE_URL 替换为对容器映像的引用,例如 gcr.io/myproject/my-image:latest
  • SIZE 替换为适当值(见上文)。

YAML

您可以使用 gcloud run services describe --format export 命令下载并查看现有服务配置,该命令会生成清理后的 YAML 格式的结果。然后,您可以使用 gcloud beta run services replace 命令修改下述字段并上传修改后的 YAML。请务必仅修改记录的字段。

  1. 要查看和下载配置,请运行以下命令:

    gcloud run services describe SERVICE --format export > service.yaml
  2. 更新 memory 特性:

    apiVersion: serving.knative.dev/v1
    kind: Service
    metadata:
      name: SERVICE
    spec:
      template:
        spec:
          containers:
          - image: IMAGE
            resources:
              limits:
                memory: SIZE

    替换

    • SERVICE 替换为您的 Cloud Run 服务的名称
    • IMAGE 替换为容器映像的网址。
    • SIZE 替换为所需的内存大小。可以表示为定点数或浮点数后接 GMK 单位的形式(这些单位分别代表千兆字节、兆字节、千字节),也可以表示为等效的 2 的幂次方数(即 GiMiKi,这些单位分别代表吉比字节、兆比字节、千字节)。
  3. 使用以下命令将服务替换为其新配置:

    gcloud beta run services replace service.yaml

最大内存量

您最多可以配置 8 吉比字节 (8Gi) 内存。

优化内存

您可以通过以下方式确定服务所需的最高内存:(常规内存) + (每项请求所需的内存) * (服务并发请求数)

由此可见:

  • 如果提高服务的并发请求数,则还应增加内存限制,以应对使用高峰。

  • 如果降低服务的并发请求数,则应考虑减小内存限制,以节省内存使用费用。

如需详细了解如何最大限度地降低每个请求的内存用量,请参阅关于全局变量的开发提示

查看内存限制设置

如需查看服务的当前内存限制设置,请执行以下操作:

控制台

  1. 转到 Cloud Run

  2. 点击您感兴趣的服务以打开“服务详细信息”页面。

  3. 点击修订版本标签页。

  4. 在右侧的详细信息面板中,“容器”标签页下列出了内存限制设置。

命令行

  1. 使用以下命令:

    gcloud run services describe SERVICE
  2. 在返回的配置中找到内存限制设置。