Cloud Run health checks ensure that your container instances are running correctly and are able to serve traffic. With Cloud Run health checks, you can customize when your container is ready to receive requests, and when your container should be considered unhealthy to require a restart.
Use cases
You can configure two types of health check probes:
- Startup probes determine whether the container has started and is ready to accept traffic. - When you configure a startup probe, liveness checks are disabled until the startup probe determines that the container is started, to prevent interference with the service startup.
- Startup probes are especially useful if you use liveness checks on slow starting containers, because startup probes prevents the containers from being shut down prematurely before the containers are up and running.
 
- Liveness probes determine whether to restart a container. - Restarting a container in this case can increase service availability in the event of bugs.
- Liveness probes are intended to restart individual instances that can't be recovered in any other way. They should be used primarily for unrecoverable instance failures, such as catching a deadlock where a service is running, but is unable to make progress. You can require a liveness probe for every container by using custom organization policies.
 
When a service experiences repeated startup or liveness probe failures, Cloud Run limits instance restarts to prevent uncontrolled crash loops.
Configure probes
Any configuration change leads to the creation of a new revision. Subsequent revisions will also automatically get this configuration setting unless you make explicit updates to change it.
Configure startup probes
You can configure HTTP, TCP, and gRPC probes using Google Cloud console, YAML, or Terraform:
Console
- In the Google Cloud console, go to the Cloud Run page: 
- For a new service, expand Container(s), Volumes, Networking, Security to display the health check options. For an existing service, click the service you want to configure, then click Edit and deploy to display the health check options. 
- In the Container(s) section, go to Health checks and click Add health check to open the Add health check configuration panel. 
- From the Select health check type menu, select the type of health check you want to add. 
- From the Select probe type menu, select the type of the probe you want to use, for example, HTTP or gRPC. This displays the probe configuration form. 
- Note that probe configuration varies by probe type. Configure the probe settings: - If you are using HTTP probes: - Make sure your service uses HTTP/1 (the Cloud Run default), not HTTP/2. 
- Use the Path field to specify the relative path to the endpoint, for example, - /.
- Select the HTTP Headers checkbox to specify optional custom headers. Specify the header name in the Name field and header value in the Value field. Click Add HTTP header to specify more headers. 
 
- If you are using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol. 
- For Port, specify the container port used for your service. 
- For Initial delay, specify the number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds. 
- For Period, specify the period (in seconds) at which to perform the probe. For example - 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
- For Failure threshold, specify the number of times to retry the probe before shutting down the container. The default value is 3. 
- For Timeout, specify the number of seconds to wait until the probe times out. This value cannot exceed the value specified for - periodSeconds. Specify a value from 1 to 240. The default is 1.
 
- Click Add to add the new threshold 
gcloud
TCP startup
Run the following command:
  gcloud run deploy SERVICE \
      --image=IMAGE_URL \
      --startup-probe tcpSocket.port=CONTAINER_PORT,initialDelaySeconds=DELAY,failureThreshold=THRESHOLD,timeoutSeconds=TIMEOUT,periodSeconds=PERIOD
Replace:
- SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) TIMEOUT with the number of seconds to wait until the probe
times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 240. The default is 1.
- THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- PERIOD with the period (in seconds) at which to perform the probe.
For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
HTTP startup
Run the following command:
  gcloud run deploy SERVICE \
      --image=IMAGE_URL \
      --startup-probe httpGet.path=PATH,httpGet.port=CONTAINER_PORT,initialDelaySeconds=DELAY,failureThreshold=THRESHOLD,timeoutSeconds=TIMEOUT,periodSeconds=PERIOD
Replace:
- SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- PATH with the relative path to the HTTP endpoint, for example, /ready.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL)TIMEOUT with the number of seconds to wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 240. The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
gRPC startup
Before using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol.
Run the following command:
  gcloud run deploy SERVICE \
      --image=IMAGE_URL \
      --startup-probe grpc.port=CONTAINER_PORT,grpc.service=GRPC_SERVICE,initialDelaySeconds=DELAY,failureThreshold=THRESHOLD,timeoutSeconds=TIMEOUT,periodSeconds=PERIOD
Replace:
- SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- (OPTIONAL) GRPC_SERVICE. If set, this is used in the
service field of the grpc.health.v1.HealthCheckRequestwhen thegrpc.health.v1.Health.Checkrpc is called.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL)TIMEOUT with the number of seconds to wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 240. The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
YAML
TCP startup
- 
If you are creating a new service, skip this step. If you are updating an existing service, download
its YAML configuration:
  gcloud run services describe SERVICE --format export > service.yaml 
- Configure the - startupProbeattribute as shown:- apiVersion: serving.knative.dev/v1 kind: Service metadata: name: SERVICE spec: template: metadata: spec: containers: - image: IMAGE_URL startupProbe: tcpSocket: port: CONTAINER_PORT initialDelaySeconds: DELAY timeoutSeconds: TIMEOUT failureThreshold: THRESHOLD periodSeconds: PERIOD - Replace: - SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) TIMEOUT with the number of seconds to wait until the probe
times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 240. The default is 1.
- THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- PERIOD with the period (in seconds) at which to perform the probe.
For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
 
- 
Create or update the service using the following command:
  gcloud run services replace service.yaml 
HTTP startup
- 
If you are creating a new service, skip this step. If you are updating an existing service, download
its YAML configuration:
  gcloud run services describe SERVICE --format export > service.yaml 
- Make sure your service uses HTTP/1 (the Cloud Run default), not HTTP/2. 
- Configure the - startupProbeattribute as shown:- apiVersion: serving.knative.dev/v1 kind: Service metadata: name: SERVICE spec: template: metadata: spec: containers: - image: IMAGE_URL startupProbe: httpGet: path: PATH port: CONTAINER_PORT httpHeaders: - name: HEADER_NAME value: HEADER_VALUE initialDelaySeconds: DELAY timeoutSeconds: TIMEOUT failureThreshold: THRESHOLD periodSeconds: PERIOD - Replace: - SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- PATH with the relative path to the HTTP endpoint, for example, /ready.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL) httpHeaderscan be used to supply multiple or repeated custom headers using the HEADER_NAME and HEADER_VALUE fields as shown.
- (OPTIONAL)TIMEOUT with the number of seconds to wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 240. The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
 
- 
Create or update the service using the following command:
  gcloud run services replace service.yaml 
gRPC startup
Before using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol.
- 
If you are creating a new service, skip this step. If you are updating an existing service, download
its YAML configuration:
  gcloud run services describe SERVICE --format export > service.yaml 
- Configure the - startupProbeattribute as shown:- apiVersion: serving.knative.dev/v1 kind: Service metadata: name: SERVICE spec: template: metadata: spec: containers: - image: IMAGE_URL startupProbe: grpc: service: GRPC_SERVICE port: CONTAINER_PORT initialDelaySeconds: DELAY timeoutSeconds: TIMEOUT failureThreshold: THRESHOLD periodSeconds: PERIOD - Replace: - SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- (OPTIONAL) GRPC_SERVICE. If set, this is used in the
service field of the grpc.health.v1.HealthCheckRequestwhen thegrpc.health.v1.Health.Checkrpc is called.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL)TIMEOUT with the number of seconds to wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 240. The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
 
- 
Create or update the service using the following command:
  gcloud run services replace service.yaml 
Terraform
To learn how to apply or remove a Terraform configuration, see Basic Terraform commands.
TCP startup
Configure your Cloud Run service with startup_probe attribute as shown:
HTTP startup
Make sure your service uses HTTP/1 (the Cloud Run default), not HTTP/2.
Configure your Cloud Run service with startup_probe attribute as shown:
gRPC startup
Before using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol.
Configure your Cloud Run service with startup_probe attribute as shown:
The default TCP startup probe
If you don't explicitly configure a TCP startup probe for a new Cloud Run service, Cloud Run automatically configures a TCP startup probe with the following default values:
startupProbe:
          timeoutSeconds: 240
          periodSeconds: 240
          failureThreshold: 1
You can change these default values following the instructions in the probe configuration section on this page.
Startup probe requirements and behavior
| Probe Type | Requirements | Behavior | 
|---|---|---|
| TCP startup | None | By default, Cloud Run makes a TCP connection to open the TCP Socket on the specified port. If Cloud Run is unable to establish a connection, it indicates a failure. If a startup probe does not succeed within the specified time ( failureThreshold*periodSeconds), which cannot exceed 240 seconds, the container is shut down. See also TCP defaults. | 
| HTTP startup | Create an HTTP health check endpoint Use HTTP/1 | After probe configuration, Cloud Run makes an HTTP GET request to the service health check endpoint (for example, /ready). Any2XXor3XXresponse is a success, everything else indicates failure.If a startup probe does not succeed within the specified time ( failureThreshold*periodSeconds), which cannot exceed 240 seconds, the container is shut down.If the HTTP startup probe succeeds within the specified time, and you have configured an HTTP liveness probe, the HTTP liveness probe is started. | 
| gRPC startup | Implement the gRPC Health Checking protocol in your Cloud Run service | If a startup probe does not succeed within the specified time ( failureThreshold*periodSeconds), which cannot exceed 240 seconds, the container is shut down. | 
Configure liveness probes
You can configure HTTP and gRPC probes using Google Cloud console, YAML, or Terraform:
Console
Before using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol.
- In the Google Cloud console, go to the Cloud Run page: 
- For a new service, expand Container(s), Volumes, Networking, Security to display the health check options. For an existing service, click the service you want to configure, then click Edit and deploy to display the health check options. 
- In the Container(s) section, go to Health checks and click Add health check to open the Add health check configuration panel. 
- From the Select health check type menu, select the type of health check you want to add. 
- From the Select probe type menu, select the type of the probe you want to use, for example, HTTP or gRPC. This displays the probe configuration form. 
- Note that probe configuration varies by probe type. Configure the probe settings: - If you are using HTTP probes: - Make sure your service uses HTTP/1 (the Cloud Run default), not HTTP/2. 
- Use the Path field to specify the relative path to the endpoint, for example, - /.
- Select the HTTP Headers checkbox to specify optional custom headers. Specify the header name in the Name field and header value in the Value field. Click Add HTTP header to specify more headers. 
 
- If you are using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol. 
- For Port, specify the container port used for your service. 
- For Initial delay, specify the number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds. 
- For Period, specify the period (in seconds) at which to perform the probe. For example - 2to perform the probe every 2 seconds. Specify a value from 1 second to 240 seconds. The default value is 10 seconds.
- For Failure threshold, specify the number of times to retry the probe before shutting down the container. The default value is 3. 
- For Timeout, specify the number of seconds to wait until the probe times out. This value cannot exceed the value specified for - periodSeconds. Specify a value from 1 to 240. The default is 1.
 
- Click Add to add the new threshold 
gcloud
HTTP liveness
Run the following command:
  gcloud run deploy SERVICE \
      --image=IMAGE_URL \
      --liveness-probe httpGet.path=PATH,httpGet.port=CONTAINER_PORT,initialDelaySeconds=DELAY,failureThreshold=THRESHOLD,timeoutSeconds=TIMEOUT,periodSeconds=PERIOD
Replace:
- SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- PATH with the relative path to the HTTP endpoint, for example, /ready.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL) TIMEOUT with the number of seconds to
wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 3600.The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 3600 seconds. The default value is 10 seconds.
gRPC liveness
Before using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol.
Run the following command:
  gcloud run deploy SERVICE \
      --image=IMAGE_URL \
      --liveness-probe grpc.port=CONTAINER_PORT,grpc.service=GRPC_SERVICE,initialDelaySeconds=DELAY,failureThreshold=THRESHOLD,timeoutSeconds=TIMEOUT,periodSeconds=PERIOD
Replace:
- SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- (OPTIONAL) GRPC_SERVICE. If set, this is used in the
service field of the grpc.health.v1.HealthCheckRequestwhen thegrpc.health.v1.Health.Checkrpc is called.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL) TIMEOUT with the number of seconds to
wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 3600.The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 3600 seconds. The default value is 10 seconds.
YAML
HTTP liveness
- 
If you are creating a new service, skip this step. If you are updating an existing service, download
its YAML configuration:
  gcloud run services describe SERVICE --format export > service.yaml 
- Make sure your service uses HTTP/1 (the Cloud Run default), not HTTP/2. 
- Configure the - livenessProbeattribute as shown:- apiVersion: serving.knative.dev/v1 kind: Service metadata: name: SERVICE spec: template: metadata: spec: containers: - image: IMAGE_URL livenessProbe: httpGet: path: PATH port: CONTAINER_PORT httpHeaders: - name: HEADER_NAME value: HEADER_VALUE initialDelaySeconds: DELAY timeoutSeconds: TIMEOUT failureThreshold: THRESHOLD periodSeconds: PERIOD - Replace: - SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- PATH with the relative path to the HTTP endpoint, for example, /ready.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL) httpHeaderscan be used to supply multiple or repeated custom headers using the HEADER_NAME and HEADER_VALUE fields as shown.
- (OPTIONAL) TIMEOUT with the number of seconds to
wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 3600.The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 3600 seconds. The default value is 10 seconds.
 
- 
Create or update the service using the following command:
  gcloud run services replace service.yaml 
gRPC liveness
Before using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol.
- 
If you are creating a new service, skip this step. If you are updating an existing service, download
its YAML configuration:
  gcloud run services describe SERVICE --format export > service.yaml 
- Configure the - livenessProbeattribute as shown:- apiVersion: serving.knative.dev/v1 kind: Service metadata: name: SERVICE spec: template: metadata: spec: containers: - image: IMAGE_URL livenessProbe: grpc: port: CONTAINER_PORT service: GRPC_SERVICE initialDelaySeconds: DELAY timeoutSeconds: TIMEOUT failureThreshold: THRESHOLD periodSeconds: PERIOD - Replace - SERVICE with the name of your Cloud Run service.
- IMAGE_URL with a reference to the container image, for example,
us-docker.pkg.dev/cloudrun/container/hello:latest. If you use Artifact Registry, the repository REPO_NAME must already be created. The URL has the shapeLOCATION-docker.pkg.dev/PROJECT_ID/REPO_NAME/PATH:TAG
- (OPTIONAL) GRPC_SERVICE. If set, this is used in the
service field of the grpc.health.v1.HealthCheckRequestwhen thegrpc.health.v1.Health.Checkrpc is called.
- (OPTIONAL) CONTAINER_PORT should be set to the container port used for your service.
- (OPTIONAL) DELAY with number of seconds to wait after the container has started before performing the first probe. Specify a value from 0 seconds to 240 seconds. The default value is 0 seconds.
- (OPTIONAL) THRESHOLD with the number of times to retry the probe before shutting down the container. The default value is 3.
- (OPTIONAL) TIMEOUT with the number of seconds to
wait until the probe times out. This value cannot exceed the value specified for periodSeconds. Specify a value from 1 to 3600.The default is 1.
- (OPTIONAL) PERIOD with the period (in seconds) at which to perform the probe. For example 2to perform the probe every 2 seconds. Specify a value from 1 second to 3600 seconds. The default value is 10 seconds.
 
- 
Create or update the service using the following command:
  gcloud run services replace service.yaml 
Terraform
To learn how to apply or remove a Terraform configuration, see Basic Terraform commands.
HTTP liveness
Make sure your service uses HTTP/1 (the Cloud Run default), not HTTP/2.
Configure your Cloud Run service with liveness_probe attribute as shown:
gRPC liveness
Before using gRPC probes, ensure that your container image implements the gRPC health check protocol. For more information, see GRPC Health Checking Protocol.
Configure your Cloud Run service with liveness_probe attribute as shown:
Liveness probe requirements and behavior
| Probe Type | Requirements | Behavior | 
|---|---|---|
| HTTP liveness | Create an HTTP health check endpoint Use HTTP/1 | The liveness probe starts only after the startup probe is successful. After probe configuration, and any startup probe is successful, Cloud Run makes an HTTP GET request to the service health check endpoint (for example, /health). Any2XXor3XXresponse is a success, everything else indicates failure.If a liveness probe does not succeed within the specified time ( failureThreshold*periodSeconds), the container is shut down using aSIGKILLsignal. Any remaining requests that were still being served by the container are terminated with the HTTP status code503. After the container is shut down, Cloud Run autoscaling starts up a new container instance. | 
| gRPC liveness | Implement the gRPC Health Checking protocol in your Cloud Run service | If you configure a gRPC startup probe, the liveness probe starts only after the startup probe is successful. After the liveness probe is configured, and any startup probe is successful, Cloud Run makes a health check request to the service. If a liveness probe does not succeed within the specified time ( failureThreshold*periodSeconds), the container is shut down using aSIGKILLsignal. After the container is shut down, Cloud Run autoscaling starts up a new container instance. | 
Create HTTP health check endpoints
If you configure your Cloud Run service for an HTTP startup probe,
you need to add an endpoint in your service code to respond to
the probe. The endpoint can have whatever name you want, for example,
/startup or /ready, but they must match the values you specify for
path in the probe configuration, as follows:
startupProbe: httpGet: path: /ready
If you configure your Cloud Run service for an HTTP liveness probe
using a path such as /health, you define it in your probe configuration as
follows:
livenessProbe: httpGet: path: /health
HTTP Healthcheck endpoints are externally accessible and follow the same principles as any other HTTP service endpoints that are exposed externally.
CPU allocation
- CPU is always allocated when probes run.
- All probes are billed for CPU and memory usage consumption, but there is no request-based charge.