- INFORMATION
- 
gcloud beta compute backend-services updateis supported in universe domainuniverse; however, some of the values used in the help text may not be available. Command examples may not work as-is and may requires changes before execution.
- NAME
- 
- gcloud beta compute backend-services update - update a backend service
 
- SYNOPSIS
- 
- 
gcloud beta compute backend-services updateBACKEND_SERVICE_NAME[--affinity-cookie-name=AFFINITY_COOKIE_NAME] [--affinity-cookie-path=AFFINITY_COOKIE_PATH] [--affinity-cookie-ttl=AFFINITY_COOKIE_TTL] [--cache-key-include-host] [--cache-key-include-http-header=[HEADER_FIELD_NAME,…]] [--cache-key-include-named-cookie=[NAMED_COOKIE,…]] [--cache-key-include-protocol] [--cache-key-include-query-string] [--cache-mode=CACHE_MODE] [--compression-mode=COMPRESSION_MODE] [--connection-drain-on-failover] [--connection-draining-timeout=CONNECTION_DRAINING_TIMEOUT] [--connection-persistence-on-unhealthy-backends=CONNECTION_PERSISTENCE_ON_UNHEALTHY_BACKENDS] [--description=DESCRIPTION] [--drop-traffic-if-unhealthy] [--edge-security-policy=EDGE_SECURITY_POLICY] [--[no-]enable-cdn] [--[no-]enable-logging] [--[no-]enable-strong-affinity] [--external-managed-migration-testing-percentage=EXTERNAL_MANAGED_MIGRATION_TESTING_PERCENTAGE] [--failover-ratio=FAILOVER_RATIO] [--health-checks=HEALTH_CHECK,[…]] [--no-health-checks] [--http-health-checks=HTTP_HEALTH_CHECK,[…]] [--https-health-checks=HTTPS_HEALTH_CHECK,[…]] [--iap=disabled|enabled,[oauth2-client-id=OAUTH2-CLIENT-ID,oauth2-client-secret=OAUTH2-CLIENT-SECRET]] [--idle-timeout-sec=IDLE_TIMEOUT_SEC] [--ip-address-selection-policy=IP_ADDRESS_SELECTION_POLICY] [--ip-port-dynamic-forwarding] [--load-balancing-scheme=LOAD_BALANCING_SCHEME] [--logging-optional=LOGGING_OPTIONAL] [--logging-optional-fields=[LOGGING_OPTIONAL_FIELDS,…]] [--logging-sample-rate=LOGGING_SAMPLE_RATE] [--port-name=PORT_NAME] [--protocol=PROTOCOL] [--[no-]request-coalescing] [--security-policy=SECURITY_POLICY] [--session-affinity=SESSION_AFFINITY] [--signed-url-cache-max-age=SIGNED_URL_CACHE_MAX_AGE] [--subsetting-policy=SUBSETTING_POLICY; default="NONE"] [--subsetting-subset-size=SUBSETTING_SUBSET_SIZE] [--timeout=TIMEOUT] [--tracking-mode=TRACKING_MODE] [--zonal-affinity-spillover=ZONAL_AFFINITY_SPILLOVER] [--zonal-affinity-spillover-ratio=ZONAL_AFFINITY_SPILLOVER_RATIO] [--bypass-cache-on-request-headers=BYPASS_CACHE_ON_REQUEST_HEADERS|--no-bypass-cache-on-request-headers] [--cache-key-query-string-blacklist=[QUERY_STRING,…] |--cache-key-query-string-whitelist=QUERY_STRING,[…]] [--clear-custom-metrics|--custom-metrics=[CUSTOM_METRICS,…] |--custom-metrics-file=[CUSTOM_METRICS,…]] [--clear-external-managed-migration-state|--external-managed-migration-state=EXTERNAL_MANAGED_MIGRATION_STATE] [--client-ttl=CLIENT_TTL|--no-client-ttl] [--custom-request-header=CUSTOM_REQUEST_HEADER|--no-custom-request-headers] [--custom-response-header=CUSTOM_RESPONSE_HEADER|--no-custom-response-headers] [--default-ttl=DEFAULT_TTL|--no-default-ttl] [--global|--region=REGION] [--global-health-checks|--health-checks-region=HEALTH_CHECKS_REGION] [--locality-lb-policy=LOCALITY_LB_POLICY|--no-locality-lb-policy] [--max-ttl=MAX_TTL|--no-max-ttl] [--[no-]negative-caching|--no-negative-caching-policies|--negative-caching-policy=[[CODE=TTL],…]] [--serve-while-stale=SERVE_WHILE_STALE|--no-serve-while-stale] [--service-bindings=SERVICE_BINDING,[…] |--no-service-bindings] [--service-lb-policy=SERVICE_LOAD_BALANCING_POLICY|--no-service-lb-policy] [--tls-settings=[authenticationConfig=AUTHENTICATIONCONFIG],[sni=SNI] |--no-tls-settings] [GCLOUD_WIDE_FLAG …]
 
- 
- DESCRIPTION
- 
(BETA)gcloud beta compute backend-services updateis used to update backend services.
- POSITIONAL ARGUMENTS
- 
- BACKEND_SERVICE_NAME
- Name of the backend service to update.
 
- FLAGS
- 
- 
If --session-affinityis set toHTTP_COOKIEorSTRONG_COOKIE_AFFINITY, this flag sets the name of the cookie.
- 
If --session-affinityis set toHTTP_COOKIEorSTRONG_COOKIE_AFFINITY, this flag sets the path of the cookie.
- 
If --session-affinityis set toGENERATED_COOKIE,HTTP_COOKIE, orSTRONG_COOKIE_AFFINITY, this flag sets the TTL, in seconds, of the resulting cookie. A setting of 0 indicates that the cookie should be a session cookie. See $ gcloud topic datetimes for information on duration formats.
- --cache-key-include-host
- Enable including host in cache key. If enabled, requests to different hosts will be cached separately. Can only be applied for global resources.
- --cache-key-include-http-header=[- HEADER_FIELD_NAME,…]
- Specifies a comma-separated list of HTTP headers, by field name, to include in cache keys. Only the request URL is included in the cache key by default.
- Specifies a comma-separated list of HTTP cookie names to include in cache keys. The name=value pair are used in the cache key Cloud CDN generates. Cookies are not included in cache keys by default.
- --cache-key-include-protocol
- Enable including protocol in cache key. If enabled, http and https requests will be cached separately. Can only be applied for global resources.
- --cache-key-include-query-string
- Enable including query string in cache key. If enabled, the query string parameters will be included according to --cache-key-query-string-whitelist and --cache-key-query-string-blacklist. If disabled, the entire query string will be excluded. Use "--cache-key-query-string-blacklist=" (sets the blacklist to the empty list) to include the entire query string. Can only be applied for global resources.
- --cache-mode=- CACHE_MODE
- 
Specifies the cache setting for all responses from this backend.
CACHE_MODEmust be one of:- CACHE_ALL_STATIC
- Automatically cache static content, including common image formats, media (video and audio), web assets (JavaScript and CSS). Requests and responses that are marked as uncacheable, as well as dynamic content (including HTML), aren't cached.
- FORCE_CACHE_ALL
- Cache all content, ignoring any "private", "no-store" or "no-cache" directives in Cache-Control response headers. Warning: this may result in Cloud CDN caching private, per-user (user identifiable) content. You should only enable this on backends that are not serving private or dynamic content, such as storage buckets.
- USE_ORIGIN_HEADERS
- Require the origin to set valid caching headers to cache content. Responses without these headers aren't cached at Google's edge, and require a full trip to the origin on every request, potentially impacting performance and increasing load on the origin server.
 
- --compression-mode=- COMPRESSION_MODE
- 
Compress text responses using Brotli or gzip compression, based on the client's
Accept-Encoding header. Two modes are supported: AUTOMATIC (recommended) -
automatically uses the best compression based on the Accept-Encoding header sent
by the client. In most cases, this will result in Brotli compression being
favored. DISABLED - disables compression. Existing compressed responses cached
by Cloud CDN will not be served to clients.
COMPRESSION_MODEmust be one of:DISABLED,AUTOMATIC.
- --connection-drain-on-failover
- Applicable only for backend service-based external and internal passthrough Network Load Balancers as part of a connection tracking policy. Only applicable when the backend service protocol is TCP. Not applicable to any other load balancer. Enabled by default, this option instructs the load balancer to allow established TCP connections to persist for up to 300 seconds on instances or endpoints in primary backends during failover, and on instances or endpoints in failover backends during failback. For details, see: Connection draining on failover and failback for internal passthrough Network Load Balancers and Connection draining on failover and failback for external passthrough Network Load Balancers.
- --connection-draining-timeout=- CONNECTION_DRAINING_TIMEOUT
- Connection draining timeout to be used during removal of VMs from instance groups. This guarantees that for the specified time all existing connections to a VM will remain untouched, but no new connections will be accepted. Set timeout to zero to disable connection draining. Enable feature by specifying a timeout of up to one hour. If the flag is omitted API default value (0s) will be used. See $ gcloud topic datetimes for information on duration formats.
- --connection-persistence-on-unhealthy-backends=- CONNECTION_PERSISTENCE_ON_UNHEALTHY_BACKENDS
- 
Specifies connection persistence when backends are unhealthy. The default value
is DEFAULT_FOR_PROTOCOL.
CONNECTION_PERSISTENCE_ON_UNHEALTHY_BACKENDSmust be one of:DEFAULT_FOR_PROTOCOL,NEVER_PERSIST,ALWAYS_PERSIST.
- --description=- DESCRIPTION
- An optional, textual description for the backend service.
- --drop-traffic-if-unhealthy
- Applicable only for backend service-based external and internal passthrough Network Load Balancers as part of a connection tracking policy. Not applicable to any other load balancer. This option instructs the load balancer to drop packets when all instances or endpoints in primary and failover backends do not pass their load balancer health checks. For details, see: Dropping traffic when all backend VMs are unhealthy for internal passthrough Network Load Balancers and Dropping traffic when all backend VMs are unhealthy for external passthrough Network Load Balancers.
- --edge-security-policy=- EDGE_SECURITY_POLICY
- The edge security policy that will be set for this backend service. To remove the policy from this backend service set the policy to an empty string.
- --[no-]enable-cdn
- 
Enable or disable Cloud CDN for the backend service. Only available for backend
services with --load-balancing-scheme=EXTERNAL or EXTERNAL_MANAGED that use a
--protocol of HTTP, HTTPS, HTTP2 or H2C. Cloud CDN caches HTTP responses at the
edge of Google's network. Cloud CDN is disabled by default. Use
--enable-cdnto enable and--no-enable-cdnto disable.
- --[no-]enable-logging
- 
The logging options for the load balancer traffic served by this backend
service. If logging is enabled, logs will be exported to Cloud Logging. Disabled
by default. This field cannot be specified for global external proxy Network
Load Balancers. Use --enable-loggingto enable and--no-enable-loggingto disable.
- --[no-]enable-strong-affinity
- 
Enable or disable strong session affinity. This is only available for
loadbalancingScheme EXTERNAL. Use --enable-strong-affinityto enable and--no-enable-strong-affinityto disable.
- --external-managed-migration-testing-percentage=- EXTERNAL_MANAGED_MIGRATION_TESTING_PERCENTAGE
- 
Determines the fraction of requests that should be processed by the Global
external Application Load Balancer.
The value of this field must be in the range [0, 100]. 
- --failover-ratio=- FAILOVER_RATIO
- Applicable only to backend service-based external passthrough Network load balancers and internal passthrough Network load balancers as part of a failover policy. Not applicable to any other load balancer. This option defines the ratio used to control when failover and failback occur. For details, see: Failover ratio for internal passthrough Network Load Balancers and Failover ratio for external passthrough Network Load Balancer overview.
- --health-checks=- HEALTH_CHECK,[…]
- Specifies a list of health check objects for checking the health of the backend service. Currently at most one health check can be specified. Health checks need not be for the same protocol as that of the backend service.
- --no-health-checks
- Removes all health checks for the backend service if the backend service has no backends attached.
- --http-health-checks=- HTTP_HEALTH_CHECK,[…]
- 
Specifies a list of legacy HTTP health check objects for checking the health of
the backend service.
Legacy health checks are not recommended for backend services. It is possible to use a legacy health check on a backend service for an Application Load Balancer if that backend service uses instance groups. For more information, refer to this guide: https://cloud.google.com/load-balancing/docs/health-check-concepts#lb_guide. 
- --https-health-checks=- HTTPS_HEALTH_CHECK,[…]
- 
Specifies a list of legacy HTTPS health check objects for checking the health of
the backend service.
Legacy health checks are not recommended for backend services. It is possible to use a legacy health check on a backend service for an Application Load Balancer if that backend service uses instance groups. For more information, refer to this guide: https://cloud.google.com/load-balancing/docs/health-check-concepts#lb_guide. 
- --iap=- disabled|- enabled,[- oauth2-client-id=- OAUTH2-CLIENT-ID,- oauth2-client-secret=- OAUTH2-CLIENT-SECRET]
- Change the Identity Aware Proxy (IAP) service configuration for the backend service. You can set IAP to 'enabled' or 'disabled', or modify the OAuth2 client configuration (oauth2-client-id and oauth2-client-secret) used by IAP. If any fields are unspecified, their values will not be modified. For instance, if IAP is enabled, '--iap=disabled' will disable IAP, and a subsequent '--iap=enabled' will then enable it with the same OAuth2 client configuration as the first time it was enabled. See https://cloud.google.com/iap/ for more information about this feature.
- --idle-timeout-sec=- IDLE_TIMEOUT_SEC
- Specifies how long to keep a connection tracking table entry while there is no matching traffic (in seconds). Applicable only for backend service-based external and internal passthrough Network Load Balancers as part of a connection tracking policy.
- --ip-address-selection-policy=- IP_ADDRESS_SELECTION_POLICY
- 
Specifies a preference for traffic sent from the proxy to the backend (or from
the client to the backend for proxyless gRPC).
Can only be set if load balancing scheme is INTERNAL_SELF_MANAGED, INTERNAL_MANAGED or EXTERNAL_MANAGED. The possible values are: IPV4_ONLY Only send IPv4 traffic to the backends of the backend service, regardless of traffic from the client to the proxy. Only IPv4 health checks are used to check the health of the backends. PREFER_IPV6 Prioritize the connection to the endpoint's IPv6 address over its IPv4 address (provided there is a healthy IPv6 address). IPV6_ONLY Only send IPv6 traffic to the backends of the backend service, regardless of traffic from the client to the proxy. Only IPv6 health checks are used to check the health of the backends. IP_ADDRESS_SELECTION_POLICYmust be one of:IPV4_ONLY,PREFER_IPV6,IPV6_ONLY.
- --ip-port-dynamic-forwarding
- Enables Dynamic Forwarding in IpPort selection mode.
- --load-balancing-scheme=- LOAD_BALANCING_SCHEME
- 
Only for the Global external Application Load Balancer migration.
The value of this field must be EXTERNAL or EXTERNAL_MANAGED. LOAD_BALANCING_SCHEMEmust be one of:EXTERNAL,EXTERNAL_MANAGED.
- --logging-optional=- LOGGING_OPTIONAL
- 
This field can only be specified if logging is enabled for the backend service.
Configures whether all, none, or a subset of optional fields should be added to
the reported logs. Default is EXCLUDE_ALL_OPTIONAL. This field can only be
specified for internal and external passthrough Network Load Balancers.
LOGGING_OPTIONALmust be one of:EXCLUDE_ALL_OPTIONAL,INCLUDE_ALL_OPTIONAL,CUSTOM.
- --logging-optional-fields=[- LOGGING_OPTIONAL_FIELDS,…]
- This field can only be specified if logging is enabled for the backend service and "--logging-optional" was set to CUSTOM. Contains a comma-separated list of optional fields you want to include in the logs. For example: serverInstance, serverGkeDetails.cluster, serverGkeDetails.pod.podNamespace. This can only be specified for internal and external passthrough Network Load Balancers.
- --logging-sample-rate=- LOGGING_SAMPLE_RATE
- This field can only be specified if logging is enabled for the backend service. The value of the field must be a float in the range [0, 1]. This configures the sampling rate of requests to the load balancer where 1.0 means all logged requests are reported and 0.0 means no logged requests are reported. The default value is 1.0 when logging is enabled and 0.0 otherwise.
- --port-name=- PORT_NAME
- 
Backend services for Application Load Balancers and proxy Network Load Balancers
must reference exactly one named port if using instance group backends.
Each instance group backend exports one or more named ports, which map a user-configurable name to a port number. The backend service's named port subscribes to one named port on each instance group. The resolved port number can differ among instance group backends, based on each instance group's named port list. When omitted, a backend service subscribes to a named port called http. The named port for a backend service is either ignored or cannot be set for these load balancing configurations: - For any load balancer, if the backends are not instance groups (for example, GCE_VM_IP_PORT NEGs).
- For any type of backend on a backend service for internal or external passthrough Network Load Balancers.
 See also https://cloud.google.com/load-balancing/docs/backend-service#named_ports. 
- --protocol=- PROTOCOL
- 
Protocol for incoming requests.
If the load-balancing-schemeisINTERNAL(Internal passthrough Network Load Balancer), the protocol must be one of: TCP, UDP, UNSPECIFIED.If the load-balancing-schemeisINTERNAL_SELF_MANAGED(Traffic Director), the protocol must be one of: HTTP, HTTPS, HTTP2, GRPC, H2C.If the load-balancing-schemeisINTERNAL_MANAGED(Internal Application Load Balancer), the protocol must be one of: HTTP, HTTPS, HTTP2, H2C.If the load-balancing-schemeisINTERNAL_MANAGED(Internal proxy Network Load Balancer), the protocol must be only TCP.If the load-balancing-schemeisEXTERNALandregionis not set (Classic Application Load Balancer and Classic proxy Network Load Balancer), the protocol must be one of: HTTP, HTTPS, HTTP2, TCP, SSL.If the load-balancing-schemeisEXTERNALandregionis set (External passthrough Network Load Balancer), the protocol must be one of: TCP, UDP, UNSPECIFIED.If the load-balancing-schemeisEXTERNAL_MANAGED(Global external Application Load Balancer and regional external Application Load Balancer), the protocol must be one of: HTTP, HTTPS, HTTP2, H2C.If the load-balancing-schemeisEXTERNAL_MANAGED(Global external proxy Network Load Balancer), the protocol must be one of: TCP, SSL.If the load-balancing-schemeisEXTERNAL_MANAGED(Regional external proxy Network Load Balancer), the protocol must be only TCP.
- --[no-]request-coalescing
- 
Enables request coalescing to the backend (recommended).
Request coalescing (or collapsing) combines multiple concurrent cache fill requests into a small number of requests to the origin. This can improve performance by putting less load on the origin and backend infrastructure. However, coalescing adds a small amount of latency when multiple requests to the same URL are processed, so for latency-critical applications it may not be desirable. Defaults to true. Use --request-coalescingto enable and--no-request-coalescingto disable.
- --security-policy=- SECURITY_POLICY
- The security policy that will be set for this backend service.
- --session-affinity=- SESSION_AFFINITY
- 
The type of session affinity to use. Supports both TCP and UDP.
SESSION_AFFINITYmust be one of:- CLIENT_IP
- Route requests to instances based on the hash of the client's IP address.
- CLIENT_IP_NO_DESTINATION
- Directs a particular client's request to the same backend VM based on a hash created on the client's IP address only. This is used in L4 ILB as Next-Hop scenarios. It differs from the Client-IP option in that Client-IP uses a hash based on both client-IP's address and destination address.
- CLIENT_IP_PORT_PROTO
- 
(Applicable if --load-balancing-schemeisINTERNAL) Connections from the same client IP with the same IP protocol and port will go to the same backend VM while that VM remains healthy.
- CLIENT_IP_PROTO
- 
(Applicable if --load-balancing-schemeisINTERNAL) Connections from the same client IP with the same IP protocol will go to the same backend VM while that VM remains healthy.
- GENERATED_COOKIE
- 
(Applicable if --load-balancing-schemeisINTERNAL_MANAGED,INTERNAL_SELF_MANAGED,EXTERNAL_MANAGED, orEXTERNAL) If the--load-balancing-schemeisEXTERNALorEXTERNAL_MANAGED, routes requests to backend VMs or endpoints in a NEG, based on the contents of theGCLBcookie set by the load balancer. Only applicable when--protocolis HTTP, HTTPS,HTTP2 or H2C. If the--load-balancing-schemeisINTERNAL_MANAGEDorINTERNAL_SELF_MANAGED, routes requests to backend VMs or endpoints in a NEG, based on the contents of theGCILBcookie set by the proxy. (If no cookie is present, the proxy chooses a backend VM or endpoint and sends aSet-Cookieresponse for future requests.) If the--load-balancing-schemeisINTERNAL_SELF_MANAGED, routes requests to backend VMs or endpoints in a NEG, based on the contents of a cookie set by Traffic Director. This session affinity is only valid if the load balancing locality policy is eitherRING_HASHorMAGLEV.
- HEADER_FIELD
- 
(Applicable if --load-balancing-schemeisINTERNAL_MANAGED,EXTERNAL_MANAGED, orINTERNAL_SELF_MANAGED) Route requests to backend VMs or endpoints in a NEG based on the value of the HTTP header named in the--custom-request-headerflag. This session affinity is only valid if the load balancing locality policy is eitherRING_HASHorMAGLEVand the backend service's consistent hash specifies the name of the HTTP header.
- HTTP_COOKIE
- 
(Applicable if --load-balancing-schemeisINTERNAL_MANAGED,EXTERNAL_MANAGEDorINTERNAL_SELF_MANAGED) Route requests to backend VMs or endpoints in a NEG, based on an HTTP cookie in the--affinity-cookie-nameflag (with the optional--affinity-cookie-ttlflag). If the client has not provided the cookie, the proxy generates the cookie and returns it to the client in aSet-Cookieheader. This session affinity is only valid if the load balancing locality policy is eitherRING_HASHorMAGLEVand the backend service's consistent hash specifies the HTTP cookie.
- NONE
- Session affinity is disabled.
- STRONG_COOKIE_AFFINITY
- 
(Applicable if --load-balancing-schemeisINTERNAL_MANAGEDorEXTERNAL_MANAGED) Strong cookie-based affinity, based on an HTTP cookie named in the--affinity-cookie-nameflag (with the optional--affinity-cookie-ttlflag). Connections bearing the same cookie will be served by the same backend VM while that VM remains healthy, as long as the cookie has not expired. If the--affinity-cookie-ttlflag is set to 0, the cookie will be treated as a session cookie.
 
- --signed-url-cache-max-age=- SIGNED_URL_CACHE_MAX_AGE
- 
The amount of time up to which the response to a signed URL request will be
cached in the CDN. After this time period, the Signed URL will be revalidated
before being served. Cloud CDN will internally act as though all responses from
this backend had a Cache-Control: public, max-age=[TTL]header, regardless of any existing Cache-Control header. The actual headers served in responses will not be altered.For example, specifying 12hwill cause the responses to signed URL requests to be cached in the CDN up to 12 hours. See $ gcloud topic datetimes for information on duration formats.This flag only affects signed URL requests. 
- --subsetting-policy=- SUBSETTING_POLICY; default="NONE"
- 
Specifies the algorithm used for subsetting. Default value is NONE which implies
that subsetting is disabled. For Layer 4 Internal Load Balancing, if subsetting
is enabled, only the algorithm CONSISTENT_HASH_SUBSETTING can be specified.
SUBSETTING_POLICYmust be one of:NONE,CONSISTENT_HASH_SUBSETTING.
- --subsetting-subset-size=- SUBSETTING_SUBSET_SIZE
- Number of backends per backend group assigned to each proxy instance or each service mesh client. Can only be set if subsetting policy is CONSISTENT_HASH_SUBSETTING and load balancing scheme is either INTERNAL_MANAGED or INTERNAL_SELF_MANAGED.
- --timeout=- TIMEOUT
- 
Applicable to all load balancing products except passthrough Network Load
Balancers. For internal passthrough Network Load Balancers
(load-balancing-schemeglobalload-balancing-schemetimeoutIf the protocoltimeouttimeoutFor example, for HTTP, HTTPS, HTTP2 or H2C traffic, specifying a timeoutIf the protocoltimeoutThe full range of timeout values allowed is 1 - 2,147,483,647 seconds. 
- --tracking-mode=- TRACKING_MODE
- 
Specifies the connection key used for connection tracking. The default value is
PER_CONNECTION. Applicable only for backend service-based external and internal
passthrough Network Load Balancers as part of a connection tracking policy. For
details, see: Connection
tracking mode for internal passthrough Network Load Balancers balancing and
Connection
tracking mode for external passthrough Network Load Balancers.
TRACKING_MODEmust be one of:PER_CONNECTION,PER_SESSION.
- --zonal-affinity-spillover=- ZONAL_AFFINITY_SPILLOVER
- 
Specifies whether zonal affinity is enabled or not. For further details, refer
to Zonal
affinity options.
Can only be set if load balancing scheme is INTERNAL, The possible values are: ZONAL_AFFINITY_DISABLED Default Value. Zonal Affinity is disabled. The load balancer distributes new connections to all healthy backend VMs across all zones. ZONAL_AFFINITY_STAY_WITHIN_ZONE Zonal Affinity is enabled. The load balancer distributes new connections to all healthy backend VMs in the client VM's zone only. If there are no healthy backend VMs in the client VM's zone, the load balancer distributes new connections to all backend VMs in the client VM's zone. ZONAL_AFFINITY_SPILL_CROSS_ZONE Zonal Affinity is enabled. The load balancer distributes new connections to all healthy backend VMs in the client VM's zone only. If there aren't enough healthy backend VMs in the client VM's zone, the load balancer distributes some new connections to backend VMs in zones other than the client VM's zone. This distribution depends on a configurable spillover ratio that determines when traffic starts spilling over to backend VMs in other zones. ZONAL_AFFINITY_SPILLOVERmust be one of:ZONAL_AFFINITY_DISABLED,ZONAL_AFFINITY_STAY_WITHIN_ZONE,ZONAL_AFFINITY_SPILL_CROSS_ZONE.
- --zonal-affinity-spillover-ratio=- ZONAL_AFFINITY_SPILLOVER_RATIO
- 
The value of the field can range from 0.0 to 1.0, inclusive. If not specified, a
default value of 0.0 is used.
This ratio indicates the threshold value for keeping traffic in the client VM's zone. If the proportion of healthy backend VMs in a zone falls below the configured spillover ratio, some new connections from the client VM are distributed to healthy backend VMs in zones other than the client VM's zone. For further details, refer to How ZONAL_AFFINITY_SPILL_CROSS_ZONE and spillover ratio work. 
- 
At most one of these can be specified:
- --bypass-cache-on-request-headers=- BYPASS_CACHE_ON_REQUEST_HEADERS
- 
Bypass the cache when the specified request headers are matched - e.g. Pragma or
Authorization headers. Up to 5 headers can be specified.
The cache is bypassed for all cdnPolicy.cacheMode settings. Note that requests that include these headers will always fill from origin, and may result in a large number of cache misses if the specified headers are common to many requests. Values are case-insensitive. The header name must be a valid HTTP header field token (per RFC 7230). For the list of restricted headers, see the list of required header name properties in How custom headers work. A header name must not appear more than once in the list of added headers. 
- --no-bypass-cache-on-request-headers
- Remove all bypass cache on request headers for the backend service.
 
- 
At most one of these can be specified:
- --cache-key-query-string-blacklist=[- QUERY_STRING,…]
- Specifies a comma separated list of query string parameters to exclude in cache keys. All other parameters will be included. Either specify --cache-key-query-string-whitelist or --cache-key-query-string-blacklist, not both. '&' and '=' will be percent encoded and not treated as delimiters. Can only be applied for global resources.
- --cache-key-query-string-whitelist=- QUERY_STRING,[…]
- Specifies a comma separated list of query string parameters to include in cache keys. All other parameters will be excluded. Either specify --cache-key-query-string-whitelist or --cache-key-query-string-blacklist, not both. '&' and '=' will be percent encoded and not treated as delimiters. Can only be applied for global resources.
 
- 
At most one of these can be specified:
- --clear-custom-metrics
- Clears current list of CUSTOM_METRICS.
- --custom-metrics=[- CUSTOM_METRICS,…]
- 
List of custom metrics that are used for WEIGHTED_ROUND_ROBIN locality load
balancing policy.
Example: gcloud beta compute backend-services update --custom-metrics='name=my-signal,dryRun=true'gcloud beta compute backend-services update --custom-metrics='name=my-signal,dryRun=true' --custom-metrics='name=my-signal2'gcloud beta compute backend-services update --custom-metrics='[{"name" : "my-signal", "dryRun" : true},{"name" : "my-signal2"}]'Sets custom_metricsvalue.- dryRun
- 
Sets dryRunvalue.
- name
- 
Required, sets namevalue.
 Shorthand Example:--custom-metrics=dryRun=boolean,name=string --custom-metrics=dryRun=boolean,name=string JSON Example:--custom-metrics='[{"dryRun": boolean, "name": "string"}]' File Example:--custom-metrics=path_to_file.(yaml|json) 
- --custom-metrics-file=[- CUSTOM_METRICS,…]
- 
File path to json file with custom metrics that are used for
WEIGHTED_ROUND_ROBIN locality load balancing policy.
Example: gcloud beta compute backend-services update --custom-metrics-file='customMetric.json'Sets custom_metrics_filevalue.- dryRun
- 
Sets dryRunvalue.
- name
- 
Required, sets namevalue.
 Shorthand Example:--custom-metrics-file=dryRun=boolean,name=string --custom-metrics-file=dryRun=boolean,name=string JSON Example:--custom-metrics-file='[{"dryRun": boolean, "name": "string"}]' File Example:--custom-metrics-file=path_to_file.(yaml|json) 
 
- 
At most one of these can be specified:
- --clear-external-managed-migration-state
- Clears current state of external managed migration.
- --external-managed-migration-state=- EXTERNAL_MANAGED_MIGRATION_STATE
- 
Specifies the migration state. Possible values are PREPARE, TEST_BY_PERCENTAGE,
and TEST_ALL_TRAFFIC.
To begin the migration from EXTERNAL to EXTERNAL_MANAGED, the state must be changed to PREPARE. The state must be changed to TEST_ALL_TRAFFIC before the loadBalancingScheme can be changed to EXTERNAL_MANAGED. Optionally, the TEST_BY_PERCENTAGE state can be used to migrate traffic by percentage using the --external-managed-migration-testing-percentage flag. EXTERNAL_MANAGED_MIGRATION_STATEmust be one of:PREPARE,TEST_BY_PERCENTAGE,TEST_ALL_TRAFFIC.
 
- 
At most one of these can be specified:
- --client-ttl=- CLIENT_TTL
- 
Specifies a separate client (for example, browser client) TTL, separate from the
TTL for Cloud CDN's edge caches.
This allows you to set a shorter TTL for browsers/clients, and to have those clients revalidate content against Cloud CDN on a more regular basis, without requiring revalidation at the origin. The value of clientTtl cannot be set to a value greater than that of maxTtl, but can be equal. Any cacheable response has its max-age/s-maxage directives adjusted down to the client TTL value if necessary; an Expires header will be replaced with a suitable max-age directive. The maximum allowed value is 31,622,400s (1 year). When creating a new backend with CACHE_ALL_STATIC and the field is unset, or when switching to that mode and the field is unset, a default value of 3600 is used. When the cache mode is set to "USE_ORIGIN_HEADERS", you must omit this field. 
- --no-client-ttl
- 
(DEPRECATED) Clears client TTL value.
The --no-client-ttl option is deprecated and will be removed in an upcoming release. If you're currently using this argument, you should remove it from your workflows. 
 
- 
At most one of these can be specified:
- --custom-request-header=- CUSTOM_REQUEST_HEADER
- 
Specifies a HTTP Header to be added by your load balancer. This flag can be
repeated to specify multiple headers. For example:
gcloud beta compute backend-services update NAME --custom-request-header "header-name: value" --custom-request-header "another-header:"
- --no-custom-request-headers
- Remove all custom request headers for the backend service.
 
- 
At most one of these can be specified:
- --custom-response-header=- CUSTOM_RESPONSE_HEADER
- 
Custom headers that the external Application Load Balancer adds to proxied
responses. For the list of headers, see Creating
custom headers.
Variables are not case-sensitive. 
- --no-custom-response-headers
- Remove all custom response headers for the backend service.
 
- 
At most one of these can be specified:
- --default-ttl=- DEFAULT_TTL
- 
Specifies the default TTL for cached content served by this origin for responses
that do not have an existing valid TTL (max-age or s-maxage).
The default value is 3600s for cache modes that allow a default TTL to be defined. The value of defaultTtl cannot be set to a value greater than that of maxTtl, but can be equal. When the cacheMode is set to FORCE_CACHE_ALL, the defaultTtl overwrites the TTL set in all responses. A TTL of "0" means Always revalidate. The maximum allowed value is 31,622,400s (1 year). Infrequently accessed objects may be evicted from the cache before the defined TTL. When creating a new backend with CACHE_ALL_STATIC or FORCE_CACHE_ALL and the field is unset, or when updating an existing backend to use these modes and the field is unset, a default value of 3600 is used. When the cache mode is set to "USE_ORIGIN_HEADERS", you must omit this field. 
- --no-default-ttl
- Clears default TTL value.
 
- 
At most one of these can be specified:
- --global
- If set, the backend service is global.
- --region=- REGION
- 
Region of the backend service to update. Overrides the default
compute/regionproperty value for this command invocation.
 
- 
At most one of these can be specified:
- --global-health-checks
- If set, the health checks are global.
- --health-checks-region=- HEALTH_CHECKS_REGION
- 
Region of the health checks to operate on. If not specified, you might be
prompted to select a region (interactive mode only).
To avoid prompting when this flag is omitted, you can set the compute/regiongcloud config set compute/region REGIONA list of regions can be fetched by running: gcloud compute regions listTo unset the property, run: gcloud config unset compute/regionAlternatively, the region can be stored in the environment variable CLOUDSDK_COMPUTE_REGION
 
- 
At most one of these can be specified:
- --locality-lb-policy=- LOCALITY_LB_POLICY
- 
The load balancing algorithm used within the scope of the locality.
LOCALITY_LB_POLICYmust be one of:INVALID_LB_POLICY,ROUND_ROBIN,LEAST_REQUEST,RING_HASH,RANDOM,ORIGINAL_DESTINATION,MAGLEV,WEIGHTED_MAGLEV,WEIGHTED_ROUND_ROBIN,WEIGHTED_GCP_RENDEZVOUS.
- --no-locality-lb-policy
- Removes the locality load balancing policy from the backend service.
 
- 
At most one of these can be specified:
- --max-ttl=- MAX_TTL
- 
Specifies the maximum allowed TTL for cached content served by this origin.
The default value is 86400 for cache modes that support a max TTL. Cache directives that attempt to set a max-age or s-maxage higher than this, or an Expires header more than maxTtl seconds in the future, are capped at the value of maxTtl, as if it were the value of an s-maxage Cache-Control directive. A TTL of "0" means Always revalidate. The maximum allowed value is 31,622,400s (1 year). Infrequently accessed objects may be evicted from the cache before the defined TTL. When creating a new backend with CACHE_ALL_STATIC and the field is unset, or when updating an existing backend to use these modes and the field is unset, a default value of 86400 is used. When the cache mode is set to "USE_ORIGIN_HEADERS" or "FORCE_CACHE_ALL", you must omit this field. 
- --no-max-ttl
- 
(DEPRECATED) Clears max TTL value.
The --no-max-ttl option is deprecated and will be removed in an upcoming release. If you're currently using this argument, you should remove it from your workflows. 
 
- 
At most one of these can be specified:
- --[no-]negative-caching
- 
Negative caching allows per-status code cache TTLs to be set, in order to apply
fine-grained caching for common errors or redirects. This can reduce the load on
your origin and improve the end-user experience by reducing response latency.
Negative caching applies to a set of 3xx, 4xx, and 5xx status codes that are typically useful to cache. Status codes not listed here cannot have their TTL explicitly set and aren't cached, in order to avoid cache poisoning attacks. HTTP success codes (HTTP 2xx) are handled by the values of defaultTtl and maxTtl. When the cache mode is set to CACHE_ALL_STATIC or USE_ORIGIN_HEADERS, these values apply to responses with the specified response code that lack any cache-controlorexpiresheaders.When the cache mode is set to FORCE_CACHE_ALL, these values apply to all responses with the specified response code, and override any caching headers. Cloud CDN applies the following default TTLs to these status codes: - HTTP 300 (Multiple Choice), 301, 308 (Permanent Redirects): 10m
- HTTP 404 (Not Found), 410 (Gone), 451 (Unavailable For Legal Reasons): 120s
- HTTP 405 (Method Not Found), 421 (Misdirected Request), 501 (Not Implemented): 60s
 These defaults can be overridden in cdnPolicy.negativeCachingPolicy. Use --negative-cachingto enable and--no-negative-cachingto disable.
- --no-negative-caching-policies
- Remove all negative caching policies for the backend service.
- --negative-caching-policy=[[- CODE=- TTL],…]
- 
Sets a cache TTL for the specified HTTP status code.
NegativeCaching must be enabled to config the negativeCachingPolicy. If you omit the policy and leave negativeCaching enabled, Cloud CDN's default cache TTLs are used. Note that when specifying an explicit negative caching policy, make sure that you specify a cache TTL for all response codes that you want to cache. Cloud CDN doesn't apply any default negative caching when a policy exists. CODEis the HTTP status code to define a TTL against. Only HTTP status codes 300, 301, 308, 404, 405, 410, 421, 451, and 501 can be specified as values, and you cannot specify a status code more than once.TTL is the time to live (in seconds) for which to cache responses for the specified CODE. The maximum allowed value is 1800s (30 minutes), noting that infrequently accessed objects may be evicted from the cache before the defined TTL.
 
- 
At most one of these can be specified:
- --serve-while-stale=- SERVE_WHILE_STALE
- 
Serve existing content from the cache (if available) when revalidating content
with the origin; this allows content to be served more quickly, and also allows
content to continue to be served if the backend is down or reporting errors.
This setting defines the default serve-stale duration for any cached responses that do not specify a stale-while-revalidate directive. Stale responses that exceed the TTL configured here will not be served without first being revalidated with the origin. The default limit is 86400s (1 day), which will allow stale content to be served up to this limit beyond the max-age (or s-max-age) of a cached response. The maximum allowed value is 604800 (1 week). Set this to zero (0) to disable serve-while-stale. 
- --no-serve-while-stale
- 
(DEPRECATED) Clears serve while stale value.
The --no-serve-while-stale option is deprecated and will be removed in an upcoming release. If you're currently using this argument, you should remove it from your workflows. 
 
- 
At most one of these can be specified:
- --service-bindings=- SERVICE_BINDING,[…]
- List of service bindings to be attached to this backend service. Can only be set if load balancing scheme is INTERNAL_SELF_MANAGED. If set, lists of backends and health checks must be both empty.
- --no-service-bindings
- No service bindings should be attached to the backend service.
 
- 
At most one of these can be specified:
- --service-lb-policy=- SERVICE_LOAD_BALANCING_POLICY
- Service load balancing policy to be applied to this backend service. Can only be set if load balancing scheme is EXTERNAL_MANAGED, INTERNAL_MANAGED, or INTERNAL_SELF_MANAGED. Only available for global backend services.
- --no-service-lb-policy
- No service load balancing policies should be attached to the backend service.
 
- 
At most one of these can be specified:
- --tls-settings=[- authenticationConfig=- AUTHENTICATIONCONFIG],[- sni=- SNI]
- 
Configuration for Backend Authenticated TLS and mTLS. May only be specified when
the backend protocol is SSL, HTTPS or HTTP2.
Example: $ gcloud beta compute backend-services update \ --tls-settings='sni=example.com,authenticationConfig=${AUTH_CONF\ IG_NAME}' 
- --no-tls-settings
- Clears currently set backend service TLS settings.
 
 
- 
If 
- GCLOUD WIDE FLAGS
- 
These flags are available to all commands: --access-token-file,--account,--billing-project,--configuration,--flags-file,--flatten,--format,--help,--impersonate-service-account,--log-http,--project,--quiet,--trace-token,--user-output-enabled,--verbosity.Run $ gcloud helpfor details.
- NOTES
- 
This command is currently in beta and might change without notice. These
variants are also available:
gcloud compute backend-services updategcloud alpha compute backend-services update
      gcloud beta compute backend-services update
  
  
  Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-10-14 UTC.
  
  
    
      [[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-10-14 UTC."],[],[]]