了解如何设置 Knative serving 服务必须在多长时间内返回请求响应。如果服务未在指定时间内返回响应,则请求将结束并返回错误 504
。
超时限制
超时上限因 GKE 集群的版本而异。
GKE 版本 | 默认限额 | 超时上限 |
---|---|---|
0.16.0-gke.1 及更高版本 | 300 秒 | 24 小时 |
0.15.0-gke.3 及更早版本 | 300 秒 | 900 秒 |
除了更改 Knative serving 请求超时之外,您还应检查语言框架,以了解其中是否包含专用的请求超时设置,该设置也必须进行更新。
设置和更新请求超时
任何配置更改都会导致新修订版本的创建。后续修订版本也将自动采用此配置设置,除非您进行了明确更新。
在部署新服务或更新现有服务并部署修订版本时,您可以使用 Google Cloud 控制台、Google Cloud CLI 或 YAML 文件设置请求超时:
控制台
前往 Google Cloud 控制台中的 Knative serving:
如果您是要配置一个新服务来作为部署目标,请点击创建服务。如果您要配置现有服务,请点击该服务,然后点击修改和部署新的修订版本。
在“高级设置”下,点击容器。
在请求超时字段中,输入要使用的超时值。您指定的值必须小于集群的 GKE 版本的超时限制。
点击下一步以转到下一部分。
在配置此服务的触发方式部分,选择您想使用哪个连接来调用服务。
点击创建以将映像部署到 Knative serving,然后等待部署完成。
命令行
YAML
您可以使用 gcloud run services describe
命令和 --format=export
标志将现有服务的配置下载到的 YAML 文件中。然后,您可以使用 gcloud run services replace
命令修改该 YAML 文件并部署这些更改。您必须确保仅修改指定的属性。
将服务配置下载到本地工作区上名为
service.yaml
的文件中:gcloud run services describe SERVICE --format export > service.yaml
将 SERVICE 替换为您的 Knative serving 服务的名称。
在本地文件中,更新
timeoutSeconds
属性:apiVersion: serving.knative.dev/v1 kind: Service metadata: name: SERVICE spec: template: spec: containers: - image: IMAGE timeoutSeconds: TIMEOUT
您需要将其中的:
- 将 SERVICE 替换为您的 Knative serving 服务的名称
- 将 IMAGE_URL 替换为对容器映像的引用,例如
gcr.io/cloudrun/hello
。 - 将 TIMEOUT 替换为所需的超时(以秒为单位)。
使用以下命令将服务替换为其新配置:
gcloud run services replace service.yaml