-
Notifications
You must be signed in to change notification settings - Fork 350
/
common_000.proto
1197 lines (1053 loc) · 63 KB
/
common_000.proto
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
// Copyright 2023 Google LLC
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// https://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// Generated by the C++ microgenerator.
// If you make any local changes, they will be lost.
// file:///workspace/generator/discovery/compute_public_google_rest_v1.json
// revision: 20230920
syntax = "proto3";
package google.cloud.cpp.compute.v1;
import "google/cloud/compute/v1/internal/common_029.proto";
import "google/cloud/compute/v1/internal/common_051.proto";
// Contains the configurations necessary to generate a signature for access to
// private storage buckets that support Signature Version 4 for authentication.
// The service name for generating the authentication header will always default
// to 's3'.
message AWSV4Signature {
// The access key used for s3 bucket authentication. Required for updating or
// creating a backend that uses AWS v4 signature authentication, but will not
// be returned as part of the configuration when queried with a REST API GET
// request. @InputOnly
optional string access_key = 1;
// The identifier of an access key used for s3 bucket authentication.
optional string access_key_id = 2;
// The optional version identifier for the access key. You can use this to
// keep track of different iterations of your access key.
optional string access_key_version = 3;
// The name of the cloud region of your origin. This is a free-form field with
// the name of the region your cloud uses to host your origin. For example,
// "us-east-1" for AWS or "us-ashburn-1" for OCI.
optional string origin_region = 4;
}
// Message containing information of one individual backend.
message Backend {
// Specifies how to determine whether the backend of a load balancer can
// handle additional traffic or is fully loaded. For usage guidelines, see
// Connection balancing mode. Backends must use compatible balancing modes.
// For more information, see Supported balancing modes and target capacity
// settings and Restrictions and guidance for instance groups. Note:
// Currently, if you use the API to configure incompatible balancing modes,
// the configuration might be accepted even though it has no impact and is
// ignored. Specifically, Backend.maxUtilization is ignored when
// Backend.balancingMode is RATE. In the future, this incompatible combination
// will be rejected.
// CONNECTION: Balance based on the number of simultaneous connections.
// RATE: Balance based on requests per second (RPS).
// UTILIZATION: Balance based on the backend utilization.
optional string balancing_mode = 1;
// A multiplier applied to the backend's target capacity of its balancing
// mode. The default value is 1, which means the group serves up to 100% of
// its configured capacity (depending on balancingMode). A setting of 0 means
// the group is completely drained, offering 0% of its available capacity. The
// valid ranges are 0.0 and [0.1,1.0]. You cannot configure a setting larger
// than 0 and smaller than 0.1. You cannot configure a setting of 0 when there
// is only one backend attached to the backend service. Not available with
// backends that don't support using a balancingMode. This includes backends
// such as global internet NEGs, regional serverless NEGs, and PSC NEGs.
optional float capacity_scaler = 2;
// An optional description of this resource. Provide this property when you
// create the resource.
optional string description = 3;
// This field designates whether this is a failover backend. More than one
// failover backend can be configured for a given BackendService.
optional bool failover = 4;
// The fully-qualified URL of an instance group or network endpoint group
// (NEG) resource. To determine what types of backends a load balancer
// supports, see the [Backend services
// overview](https://cloud.google.com/load-balancing/docs/backend-service#backends).
// You must use the *fully-qualified* URL (starting with
// https://www.googleapis.com/) to specify the instance group or NEG. Partial
// URLs are not supported.
optional string group = 5;
// Defines a target maximum number of simultaneous connections. For usage
// guidelines, see Connection balancing mode and Utilization balancing mode.
// Not available if the backend's balancingMode is RATE.
optional int32 max_connections = 6;
// Defines a target maximum number of simultaneous connections. For usage
// guidelines, see Connection balancing mode and Utilization balancing mode.
// Not available if the backend's balancingMode is RATE.
optional int32 max_connections_per_endpoint = 7;
// Defines a target maximum number of simultaneous connections. For usage
// guidelines, see Connection balancing mode and Utilization balancing mode.
// Not available if the backend's balancingMode is RATE.
optional int32 max_connections_per_instance = 8;
// Defines a maximum number of HTTP requests per second (RPS). For usage
// guidelines, see Rate balancing mode and Utilization balancing mode. Not
// available if the backend's balancingMode is CONNECTION.
optional int32 max_rate = 9;
// Defines a maximum target for requests per second (RPS). For usage
// guidelines, see Rate balancing mode and Utilization balancing mode. Not
// available if the backend's balancingMode is CONNECTION.
optional float max_rate_per_endpoint = 10;
// Defines a maximum target for requests per second (RPS). For usage
// guidelines, see Rate balancing mode and Utilization balancing mode. Not
// available if the backend's balancingMode is CONNECTION.
optional float max_rate_per_instance = 11;
// Optional parameter to define a target capacity for the UTILIZATION
// balancing mode. The valid range is [0.0, 1.0]. For usage guidelines, see
// Utilization balancing mode.
optional float max_utilization = 12;
}
// Represents a Backend Service resource. A backend service defines how Google
// Cloud load balancers distribute traffic. The backend service configuration
// contains a set of values, such as the protocol used to connect to backends,
// various distribution and session settings, health checks, and timeouts. These
// settings provide fine-grained control over how your load balancer behaves.
// Most of the settings have default values that allow for easy configuration if
// you need to get started quickly. Backend services in Google Compute Engine
// can be either regionally or globally scoped. *
// [Global](https://cloud.google.com/compute/docs/reference/rest/v1/backendServices)
// *
// [Regional](https://cloud.google.com/compute/docs/reference/rest/v1/regionBackendServices)
// For more information, see Backend Services.
message BackendService {
// Lifetime of cookies in seconds. This setting is applicable to external and
// internal HTTP(S) load balancers and Traffic Director and requires
// GENERATED_COOKIE or HTTP_COOKIE session affinity. If set to 0, the cookie
// is non-persistent and lasts only until the end of the browser session (or
// equivalent). The maximum allowed value is two weeks (1,209,600). Not
// supported when the backend service is referenced by a URL map that is bound
// to target gRPC proxy that has validateForProxyless field set to true.
optional int32 affinity_cookie_ttl_sec = 1;
// The list of backends that serve this BackendService.
repeated Backend backends = 2;
// Cloud CDN configuration for this BackendService. Only available for
// specified load balancer types.
optional BackendServiceCdnPolicy cdn_policy = 3;
optional CircuitBreakers circuit_breakers = 4;
// Compress text responses using Brotli or gzip compression, based on the
// client's Accept-Encoding header.
// AUTOMATIC: Automatically uses the best compression based on the
// Accept-Encoding header sent by the client.
// DISABLED: Disables compression. Existing compressed responses cached by
// Cloud CDN will not be served to clients.
optional string compression_mode = 5;
optional ConnectionDraining connection_draining = 6;
// Connection Tracking configuration for this BackendService. Connection
// tracking policy settings are only available for Network Load Balancing and
// Internal TCP/UDP Load Balancing.
optional BackendServiceConnectionTrackingPolicy connection_tracking_policy =
7;
// Consistent Hash-based load balancing can be used to provide soft session
// affinity based on HTTP headers, cookies or other properties. This load
// balancing policy is applicable only for HTTP connections. The affinity to a
// particular destination host will be lost when one or more hosts are
// added/removed from the destination service. This field specifies parameters
// that control consistent hashing. This field is only applicable when
// localityLbPolicy is set to MAGLEV or RING_HASH. This field is applicable to
// either: - A regional backend service with the service_protocol set to HTTP,
// HTTPS, or HTTP2, and load_balancing_scheme set to INTERNAL_MANAGED. - A
// global backend service with the load_balancing_scheme set to
// INTERNAL_SELF_MANAGED.
optional ConsistentHashLoadBalancerSettings consistent_hash = 8;
// [Output Only] Creation timestamp in RFC3339 text format.
optional string creation_timestamp = 9;
// Headers that the load balancer adds to proxied requests. See [Creating
// custom
// headers](https://cloud.google.com/load-balancing/docs/custom-headers).
repeated string custom_request_headers = 10;
// Headers that the load balancer adds to proxied responses. See [Creating
// custom
// headers](https://cloud.google.com/load-balancing/docs/custom-headers).
repeated string custom_response_headers = 11;
// An optional description of this resource. Provide this property when you
// create the resource.
optional string description = 12;
// [Output Only] The resource URL for the edge security policy associated with
// this backend service.
optional string edge_security_policy = 13;
// If true, enables Cloud CDN for the backend service of an external HTTP(S)
// load balancer.
optional bool enable_cdn = 14;
// Requires at least one backend instance group to be defined as a backup
// (failover) backend. For load balancers that have configurable failover:
// [Internal TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/internal/failover-overview)
// and [external TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview).
optional BackendServiceFailoverPolicy failover_policy = 15;
// Fingerprint of this resource. A hash of the contents stored in this object.
// This field is used in optimistic locking. This field will be ignored when
// inserting a BackendService. An up-to-date fingerprint must be provided in
// order to update the BackendService, otherwise the request will fail with
// error 412 conditionNotMet. To see the latest fingerprint, make a get()
// request to retrieve a BackendService.
optional string fingerprint = 16;
// The list of URLs to the healthChecks, httpHealthChecks (legacy), or
// httpsHealthChecks (legacy) resource for health checking this backend
// service. Not all backend services support legacy health checks. See Load
// balancer guide. Currently, at most one health check can be specified for
// each backend service. Backend services with instance group or zonal NEG
// backends must have a health check. Backend services with internet or
// serverless NEG backends must not have a health check.
repeated string health_checks = 17;
// The configurations for Identity-Aware Proxy on this resource. Not available
// for Internal TCP/UDP Load Balancing and Network Load Balancing.
optional BackendServiceIAP iap = 18;
// [Output Only] The unique identifier for the resource. This identifier is
// defined by the server.
optional string id = 19;
// [Output Only] Type of resource. Always compute#backendService for backend
// services.
optional string kind = 20;
// Specifies the load balancer type. A backend service created for one type of
// load balancer cannot be used with another. For more information, refer to
// Choosing a load balancer.
// EXTERNAL: Signifies that this will be used for external HTTP(S), SSL Proxy,
// TCP Proxy, or Network Load Balancing
// EXTERNAL_MANAGED: Signifies that this will be used for External Managed
// HTTP(S) Load Balancing.
// INTERNAL: Signifies that this will be used for Internal TCP/UDP Load
// Balancing.
// INTERNAL_MANAGED: Signifies that this will be used for Internal HTTP(S)
// Load Balancing.
// INTERNAL_SELF_MANAGED: Signifies that this will be used by Traffic
// Director.
// INVALID_LOAD_BALANCING_SCHEME:
optional string load_balancing_scheme = 21;
// A list of locality load-balancing policies to be used in order of
// preference. When you use localityLbPolicies, you must set at least one
// value for either the localityLbPolicies[].policy or the
// localityLbPolicies[].customPolicy field. localityLbPolicies overrides any
// value set in the localityLbPolicy field. For an example of how to use this
// field, see Define a list of preferred policies. Caution: This field and its
// children are intended for use in a service mesh that includes gRPC clients
// only. Envoy proxies can't use backend services that have this
// configuration.
repeated BackendServiceLocalityLoadBalancingPolicyConfig
locality_lb_policies = 22;
// The load balancing algorithm used within the scope of the locality. The
// possible values are: - ROUND_ROBIN: This is a simple policy in which each
// healthy backend is selected in round robin order. This is the default. -
// LEAST_REQUEST: An O(1) algorithm which selects two random healthy hosts and
// picks the host which has fewer active requests. - RING_HASH: The
// ring/modulo hash load balancer implements consistent hashing to backends.
// The algorithm has the property that the addition/removal of a host from a
// set of N hosts only affects 1/N of the requests. - RANDOM: The load
// balancer selects a random healthy host. - ORIGINAL_DESTINATION: Backend
// host is selected based on the client connection metadata, i.e., connections
// are opened to the same address as the destination address of the incoming
// connection before the connection was redirected to the load balancer. -
// MAGLEV: used as a drop in replacement for the ring hash load balancer.
// Maglev is not as stable as ring hash but has faster table lookup build
// times and host selection times. For more information about Maglev, see
// https://ai.google/research/pubs/pub44824 This field is applicable to
// either: - A regional backend service with the service_protocol set to HTTP,
// HTTPS, or HTTP2, and load_balancing_scheme set to INTERNAL_MANAGED. - A
// global backend service with the load_balancing_scheme set to
// INTERNAL_SELF_MANAGED, INTERNAL_MANAGED, or EXTERNAL_MANAGED. If
// sessionAffinity is not NONE, and this field is not set to MAGLEV or
// RING_HASH, session affinity settings will not take effect. Only ROUND_ROBIN
// and RING_HASH are supported when the backend service is referenced by a URL
// map that is bound to target gRPC proxy that has validateForProxyless field
// set to true.
// INVALID_LB_POLICY:
// LEAST_REQUEST: An O(1) algorithm which selects two random healthy hosts and
// picks the host which has fewer active requests.
// MAGLEV: This algorithm implements consistent hashing to backends. Maglev
// can be used as a drop in replacement for the ring hash load balancer.
// Maglev is not as stable as ring hash but has faster table lookup build
// times and host selection times. For more information about Maglev, see
// https://ai.google/research/pubs/pub44824
// ORIGINAL_DESTINATION: Backend host is selected based on the client
// connection metadata, i.e., connections are opened to the same address as
// the destination address of the incoming connection before the connection
// was redirected to the load balancer.
// RANDOM: The load balancer selects a random healthy host.
// RING_HASH: The ring/modulo hash load balancer implements consistent hashing
// to backends. The algorithm has the property that the addition/removal of a
// host from a set of N hosts only affects 1/N of the requests.
// ROUND_ROBIN: This is a simple policy in which each healthy backend is
// selected in round robin order. This is the default.
// WEIGHTED_MAGLEV: Per-instance weighted Load Balancing via health check
// reported weights. If set, the Backend Service must configure a non legacy
// HTTP-based Health Check, and health check replies are expected to contain
// non-standard HTTP response header field X-Load-Balancing-Endpoint-Weight to
// specify the per-instance weights. If set, Load Balancing is weighted based
// on the per-instance weights reported in the last processed health check
// replies, as long as every instance either reported a valid weight or had
// UNAVAILABLE_WEIGHT. Otherwise, Load Balancing remains equal-weight. This
// option is only supported in Network Load Balancing.
optional string locality_lb_policy = 23;
// This field denotes the logging options for the load balancer traffic served
// by this backend service. If logging is enabled, logs will be exported to
// Stackdriver.
optional BackendServiceLogConfig log_config = 24;
// Specifies the default maximum duration (timeout) for streams to this
// service. Duration is computed from the beginning of the stream until the
// response has been completely processed, including all retries. A stream
// that does not complete in this duration is closed. If not specified, there
// will be no timeout limit, i.e. the maximum duration is infinite. This value
// can be overridden in the PathMatcher configuration of the UrlMap that
// references this backend service. This field is only allowed when the
// loadBalancingScheme of the backend service is INTERNAL_SELF_MANAGED.
optional Duration max_stream_duration = 25;
// Deployment metadata associated with the resource to be set by a GKE hub
// controller and read by the backend RCTH
map<string, string> metadatas = 40;
// Name of the resource. Provided by the client when the resource is created.
// The name must be 1-63 characters long, and comply with RFC1035.
// Specifically, the name must be 1-63 characters long and match the regular
// expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character
// must be a lowercase letter, and all following characters must be a dash,
// lowercase letter, or digit, except the last character, which cannot be a
// dash.
optional string name = 26;
// The URL of the network to which this backend service belongs. This field
// can only be specified when the load balancing scheme is set to INTERNAL.
optional string network = 27;
// Settings controlling the ejection of unhealthy backend endpoints from the
// load balancing pool of each individual proxy instance that processes the
// traffic for the given backend service. If not set, this feature is
// considered disabled. Results of the outlier detection algorithm (ejection
// of endpoints from the load balancing pool and returning them back to the
// pool) are executed independently by each proxy instance of the load
// balancer. In most cases, more than one proxy instance handles the traffic
// received by a backend service. Thus, it is possible that an unhealthy
// endpoint is detected and ejected by only some of the proxies, and while
// this happens, other proxies may continue to send requests to the same
// unhealthy endpoint until they detect and eject the unhealthy endpoint.
// Applicable backend endpoints can be: - VM instances in an Instance Group -
// Endpoints in a Zonal NEG (GCE_VM_IP, GCE_VM_IP_PORT) - Endpoints in a
// Hybrid Connectivity NEG (NON_GCP_PRIVATE_IP_PORT) - Serverless NEGs, that
// resolve to Cloud Run, App Engine, or Cloud Functions Services - Private
// Service Connect NEGs, that resolve to Google-managed regional API endpoints
// or managed services published using Private Service Connect Applicable
// backend service types can be: - A global backend service with the
// loadBalancingScheme set to INTERNAL_SELF_MANAGED or EXTERNAL_MANAGED. - A
// regional backend service with the serviceProtocol set to HTTP, HTTPS, or
// HTTP2, and loadBalancingScheme set to INTERNAL_MANAGED or EXTERNAL_MANAGED.
// Not supported for Serverless NEGs. Not supported when the backend service
// is referenced by a URL map that is bound to target gRPC proxy that has
// validateForProxyless field set to true.
optional OutlierDetection outlier_detection = 28;
// Deprecated in favor of portName. The TCP port to connect on the backend.
// The default value is 80. For Internal TCP/UDP Load Balancing and Network
// Load Balancing, omit port.
optional int32 port = 29;
// A named port on a backend instance group representing the port for
// communication to the backend VMs in that group. The named port must be
// [defined on each backend instance
// group](https://cloud.google.com/load-balancing/docs/backend-service#named_ports).
// This parameter has no meaning if the backends are NEGs. For Internal
// TCP/UDP Load Balancing and Network Load Balancing, omit port_name.
optional string port_name = 30;
// The protocol this BackendService uses to communicate with backends.
// Possible values are HTTP, HTTPS, HTTP2, TCP, SSL, UDP or GRPC. depending on
// the chosen load balancer or Traffic Director configuration. Refer to the
// documentation for the load balancers or for Traffic Director for more
// information. Must be set to GRPC when the backend service is referenced by
// a URL map that is bound to target gRPC proxy.
// GRPC: gRPC (available for Traffic Director).
// HTTP:
// HTTP2: HTTP/2 with SSL.
// HTTPS:
// SSL: TCP proxying with SSL.
// TCP: TCP proxying or TCP pass-through.
// UDP: UDP.
// UNSPECIFIED: If a Backend Service has UNSPECIFIED as its protocol, it can
// be used with any L3/L4 Forwarding Rules.
optional string protocol = 31;
// [Output Only] URL of the region where the regional backend service resides.
// This field is not applicable to global backend services. You must specify
// this field as part of the HTTP request URL. It is not settable as a field
// in the request body.
optional string region = 32;
// [Output Only] The resource URL for the security policy associated with this
// backend service.
optional string security_policy = 33;
// This field specifies the security settings that apply to this backend
// service. This field is applicable to a global backend service with the
// load_balancing_scheme set to INTERNAL_SELF_MANAGED.
optional SecuritySettings security_settings = 34;
// [Output Only] Server-defined URL for the resource.
optional string self_link = 35;
// URLs of networkservices.ServiceBinding resources. Can only be set if load
// balancing scheme is INTERNAL_SELF_MANAGED. If set, lists of backends and
// health checks must be both empty.
repeated string service_bindings = 36;
// Type of session affinity to use. The default is NONE. Only NONE and
// HEADER_FIELD are supported when the backend service is referenced by a URL
// map that is bound to target gRPC proxy that has validateForProxyless field
// set to true. For more details, see: [Session
// Affinity](https://cloud.google.com/load-balancing/docs/backend-service#session_affinity).
// CLIENT_IP: 2-tuple hash on packet's source and destination IP addresses.
// Connections from the same source IP address to the same destination IP
// address will be served by the same backend VM while that VM remains
// healthy.
// CLIENT_IP_NO_DESTINATION: 1-tuple hash only on packet's source IP address.
// Connections from the same source IP address will be served by the same
// backend VM while that VM remains healthy. This option can only be used for
// Internal TCP/UDP Load Balancing.
// CLIENT_IP_PORT_PROTO: 5-tuple hash on packet's source and destination IP
// addresses, IP protocol, and source and destination ports. Connections for
// the same IP protocol from the same source IP address and port to the same
// destination IP address and port will be served by the same backend VM while
// that VM remains healthy. This option cannot be used for HTTP(S) load
// balancing.
// CLIENT_IP_PROTO: 3-tuple hash on packet's source and destination IP
// addresses, and IP protocol. Connections for the same IP protocol from the
// same source IP address to the same destination IP address will be served by
// the same backend VM while that VM remains healthy. This option cannot be
// used for HTTP(S) load balancing.
// GENERATED_COOKIE: Hash based on a cookie generated by the L7 loadbalancer.
// Only valid for HTTP(S) load balancing.
// HEADER_FIELD: The hash is based on a user specified header field.
// HTTP_COOKIE: The hash is based on a user provided cookie.
// NONE: No session affinity. Connections from the same client IP may go to
// any instance in the pool.
optional string session_affinity = 37;
optional Subsetting subsetting = 38;
// The backend service timeout has a different meaning depending on the type
// of load balancer. For more information see, Backend service settings. The
// default is 30 seconds. The full range of timeout values allowed goes from 1
// through 2,147,483,647 seconds. This value can be overridden in the
// PathMatcher configuration of the UrlMap that references this backend
// service. Not supported when the backend service is referenced by a URL map
// that is bound to target gRPC proxy that has validateForProxyless field set
// to true. Instead, use maxStreamDuration.
optional int32 timeout_sec = 39;
}
// Message containing Cloud CDN configuration for a backend service.
message BackendServiceCdnPolicy {
// 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.
repeated BackendServiceCdnPolicyBypassCacheOnRequestHeader
bypass_cache_on_request_headers = 1;
// The CacheKeyPolicy for this CdnPolicy.
optional CacheKeyPolicy cache_key_policy = 2;
// Specifies the cache setting for all responses from this backend. The
// possible values are: USE_ORIGIN_HEADERS Requires the origin to set valid
// caching headers to cache content. Responses without these headers will not
// be cached at Google's edge, and will require a full trip to the origin on
// every request, potentially impacting performance and increasing load on the
// origin server. 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. CACHE_ALL_STATIC Automatically cache static content,
// including common image formats, media (video and audio), and web assets
// (JavaScript and CSS). Requests and responses that are marked as
// uncacheable, as well as dynamic content (including HTML), will not be
// cached.
// CACHE_ALL_STATIC: Automatically cache static content, including common
// image formats, media (video and audio), and web assets (JavaScript and
// CSS). Requests and responses that are marked as uncacheable, as well as
// dynamic content (including HTML), will not be 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.
// INVALID_CACHE_MODE:
// USE_ORIGIN_HEADERS: Requires the origin to set valid caching headers to
// cache content. Responses without these headers will not be cached at
// Google's edge, and will require a full trip to the origin on every request,
// potentially impacting performance and increasing load on the origin server.
optional string cache_mode = 3;
// Specifies a separate client (e.g. browser client) maximum TTL. This is used
// to clamp the max-age (or Expires) value sent to the client. With
// FORCE_CACHE_ALL, the lesser of client_ttl and default_ttl is used for the
// response max-age directive, along with a "public" directive. For cacheable
// content in CACHE_ALL_STATIC mode, client_ttl clamps the max-age from the
// origin (if specified), or else sets the response max-age directive to the
// lesser of the client_ttl and default_ttl, and also ensures a "public"
// cache-control directive is present. If a client TTL is not specified, a
// default value (1 hour) will be used. The maximum allowed value is
// 31,622,400s (1 year).
optional int32 client_ttl = 4;
// 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-max-age).
// Setting a TTL of "0" means "always revalidate". 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 will overwrite
// the TTL set in all responses. The maximum allowed value is 31,622,400s (1
// year), noting that infrequently accessed objects may be evicted from the
// cache before the defined TTL.
optional int32 default_ttl = 5;
// Specifies the maximum allowed TTL for cached content served by this origin.
// 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 will be
// capped at the value of maxTTL, as if it were the value of an s-maxage
// Cache-Control directive. Headers sent to the client will not be modified.
// Setting a TTL of "0" means "always revalidate". The maximum allowed value
// is 31,622,400s (1 year), noting that infrequently accessed objects may be
// evicted from the cache before the defined TTL.
optional int32 max_ttl = 6;
// Negative caching allows per-status code 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 end-user experience by reducing response
// latency. When the cache mode is set to CACHE_ALL_STATIC or
// USE_ORIGIN_HEADERS, negative caching applies to responses with the
// specified response code that lack any Cache-Control, Expires, or Pragma:
// no-cache directives. When the cache mode is set to FORCE_CACHE_ALL,
// negative caching applies to all responses with the specified response code,
// and override any caching headers. By default, Cloud CDN will apply 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 negative_caching_policy.
optional bool negative_caching = 7;
// Sets a cache TTL for the specified HTTP status code. negative_caching must
// be enabled to configure negative_caching_policy. Omitting the policy and
// leaving negative_caching enabled will use Cloud CDN's default cache TTLs.
// Note that when specifying an explicit negative_caching_policy, you should
// take care to specify a cache TTL for all response codes that you wish to
// cache. Cloud CDN will not apply any default negative caching when a policy
// exists.
repeated BackendServiceCdnPolicyNegativeCachingPolicy
negative_caching_policy = 8;
// If true then Cloud CDN will combine multiple concurrent cache fill requests
// into a small number of requests to the origin.
optional bool request_coalescing = 9;
// Serve existing content from the cache (if available) when revalidating
// content with the origin, or when an error is encountered when refreshing
// the cache. This setting defines the default "max-stale" duration for any
// cached responses that do not specify a max-stale directive. Stale responses
// that exceed the TTL configured here will not be served. The default limit
// (max-stale) 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.
optional int32 serve_while_stale = 10;
// Maximum number of seconds the response to a signed URL request will be
// considered fresh. After this time period, the response will be revalidated
// before being served. Defaults to 1hr (3600s). When serving responses to
// signed URL requests, Cloud CDN will internally behave 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.
optional string signed_url_cache_max_age_sec = 11;
// [Output Only] Names of the keys for signing request URLs.
repeated string signed_url_key_names = 12;
}
// Bypass the cache when the specified request headers are present, e.g. Pragma
// or Authorization headers. Values are case insensitive. The presence of such a
// header overrides the cache_mode setting.
message BackendServiceCdnPolicyBypassCacheOnRequestHeader {
// The header field name to match on when bypassing cache. Values are
// case-insensitive.
optional string header_name = 1;
}
// Specify CDN TTLs for response error codes.
message BackendServiceCdnPolicyNegativeCachingPolicy {
// The HTTP status code to define a TTL against. Only HTTP status codes 300,
// 301, 302, 307, 308, 404, 405, 410, 421, 451 and 501 are can be specified as
// values, and you cannot specify a status code more than once.
optional int32 code = 1;
// The TTL (in seconds) for which to cache responses with the corresponding
// status code. The maximum allowed value is 1800s (30 minutes), noting that
// infrequently accessed objects may be evicted from the cache before the
// defined TTL.
optional int32 ttl = 2;
}
// Connection Tracking configuration for this BackendService.
message BackendServiceConnectionTrackingPolicy {
// Specifies connection persistence when backends are unhealthy. The default
// value is DEFAULT_FOR_PROTOCOL. If set to DEFAULT_FOR_PROTOCOL, the existing
// connections persist on unhealthy backends only for connection-oriented
// protocols (TCP and SCTP) and only if the Tracking Mode is PER_CONNECTION
// (default tracking mode) or the Session Affinity is configured for 5-tuple.
// They do not persist for UDP. If set to NEVER_PERSIST, after a backend
// becomes unhealthy, the existing connections on the unhealthy backend are
// never persisted on the unhealthy backend. They are always diverted to newly
// selected healthy backends (unless all backends are unhealthy). If set to
// ALWAYS_PERSIST, existing connections always persist on unhealthy backends
// regardless of protocol and session affinity. It is generally not
// recommended to use this mode overriding the default. For more details, see
// [Connection Persistence for Network Load
// Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-backend-service#connection-persistence)
// and [Connection Persistence for Internal TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/internal#connection-persistence).
// ALWAYS_PERSIST:
// DEFAULT_FOR_PROTOCOL:
// NEVER_PERSIST:
optional string connection_persistence_on_unhealthy_backends = 1;
// Enable Strong Session Affinity for Network Load Balancing. This option is
// not available publicly.
optional bool enable_strong_affinity = 2;
// Specifies how long to keep a Connection Tracking entry while there is no
// matching traffic (in seconds). For Internal TCP/UDP Load Balancing: - The
// minimum (default) is 10 minutes and the maximum is 16 hours. - It can be
// set only if Connection Tracking is less than 5-tuple (i.e. Session Affinity
// is CLIENT_IP_NO_DESTINATION, CLIENT_IP or CLIENT_IP_PROTO, and Tracking
// Mode is PER_SESSION). For Network Load Balancer the default is 60 seconds.
// This option is not available publicly.
optional int32 idle_timeout_sec = 3;
// Specifies the key used for connection tracking. There are two options: -
// PER_CONNECTION: This is the default mode. The Connection Tracking is
// performed as per the Connection Key (default Hash Method) for the specific
// protocol. - PER_SESSION: The Connection Tracking is performed as per the
// configured Session Affinity. It matches the configured Session Affinity.
// For more details, see [Tracking Mode for Network Load
// Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-backend-service#tracking-mode)
// and [Tracking Mode for Internal TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/internal#tracking-mode).
// INVALID_TRACKING_MODE:
// PER_CONNECTION:
// PER_SESSION:
optional string tracking_mode = 4;
}
// For load balancers that have configurable failover: [Internal TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/internal/failover-overview)
// and [external TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview).
// On failover or failback, this field indicates whether connection draining
// will be honored. Google Cloud has a fixed connection draining timeout of 10
// minutes. A setting of true terminates existing TCP connections to the active
// pool during failover and failback, immediately draining traffic. A setting of
// false allows existing TCP connections to persist, even on VMs no longer in
// the active pool, for up to the duration of the connection draining timeout
// (10 minutes).
message BackendServiceFailoverPolicy {
// This can be set to true only if the protocol is TCP. The default is false.
optional bool disable_connection_drain_on_failover = 1;
// If set to true, connections to the load balancer are dropped when all
// primary and all backup backend VMs are unhealthy.If set to false,
// connections are distributed among all primary VMs when all primary and all
// backup backend VMs are unhealthy. For load balancers that have configurable
// failover: [Internal TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/internal/failover-overview)
// and [external TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview).
// The default is false.
optional bool drop_traffic_if_unhealthy = 2;
// The value of the field must be in the range [0, 1]. If the value is 0, the
// load balancer performs a failover when the number of healthy primary VMs
// equals zero. For all other values, the load balancer performs a failover
// when the total number of healthy primary VMs is less than this ratio. For
// load balancers that have configurable failover: [Internal TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/internal/failover-overview)
// and [external TCP/UDP Load
// Balancing](https://cloud.google.com/load-balancing/docs/network/networklb-failover-overview).
optional float failover_ratio = 3;
}
message BackendServiceGroupHealth {
// Metadata defined as annotations on the network endpoint group.
map<string, string> annotations = 1;
// Health state of the backend instances or endpoints in requested instance or
// network endpoint group, determined based on configured health checks.
repeated HealthStatus health_status = 2;
// [Output Only] Type of resource. Always compute#backendServiceGroupHealth
// for the health of backend services.
optional string kind = 3;
}
// Identity-Aware Proxy
message BackendServiceIAP {
// Whether the serving infrastructure will authenticate and authorize all
// incoming requests.
optional bool enabled = 1;
// OAuth2 client ID to use for the authentication flow.
optional string oauth2_client_id = 2;
// OAuth2 client secret to use for the authentication flow. For security
// reasons, this value cannot be retrieved via the API. Instead, the SHA-256
// hash of the value is returned in the oauth2ClientSecretSha256 field.
// @InputOnly
optional string oauth2_client_secret = 3;
// [Output Only] SHA256 hash value for the field oauth2_client_secret above.
optional string oauth2_client_secret_sha256 = 4;
}
// Contains a list of BackendService resources.
message BackendServiceList {
// [Output Only] Unique identifier for the resource; defined by the server.
optional string id = 1;
// A list of BackendService resources.
repeated BackendService items = 2;
// [Output Only] Type of resource. Always compute#backendServiceList for lists
// of backend services.
optional string kind = 3;
// [Output Only] This token allows you to get the next page of results for
// list requests. If the number of results is larger than maxResults, use the
// nextPageToken as a value for the query parameter pageToken in the next list
// request. Subsequent list requests will have their own nextPageToken to
// continue paging through the results.
optional string next_page_token = 4;
// [Output Only] Server-defined URL for this resource.
optional string self_link = 5;
message Warning {
// [Output Only] A warning code, if applicable. For example, Compute Engine
// returns NO_RESULTS_ON_PAGE if there are no results in the response.
// CLEANUP_FAILED: Warning about failed cleanup of transient changes made by
// a failed operation.
// DEPRECATED_RESOURCE_USED: A link to a deprecated resource was created.
// DEPRECATED_TYPE_USED: When deploying and at least one of the resources
// has a type marked as deprecated
// DISK_SIZE_LARGER_THAN_IMAGE_SIZE: The user created a boot disk that is
// larger than image size.
// EXPERIMENTAL_TYPE_USED: When deploying and at least one of the resources
// has a type marked as experimental
// EXTERNAL_API_WARNING: Warning that is present in an external api call
// FIELD_VALUE_OVERRIDEN: Warning that value of a field has been overridden.
// Deprecated unused field.
// INJECTED_KERNELS_DEPRECATED: The operation involved use of an injected
// kernel, which is deprecated.
// INVALID_HEALTH_CHECK_FOR_DYNAMIC_WIEGHTED_LB: A WEIGHTED_MAGLEV backend
// service is associated with a health check that is not of type
// HTTP/HTTPS/HTTP2.
// LARGE_DEPLOYMENT_WARNING: When deploying a deployment with a exceedingly
// large number of resources
// LIST_OVERHEAD_QUOTA_EXCEED: Resource can't be retrieved due to list
// overhead quota exceed which captures the amount of resources filtered out
// by user-defined list filter.
// MISSING_TYPE_DEPENDENCY: A resource depends on a missing type
// NEXT_HOP_ADDRESS_NOT_ASSIGNED: The route's nextHopIp address is not
// assigned to an instance on the network.
// NEXT_HOP_CANNOT_IP_FORWARD: The route's next hop instance cannot ip
// forward.
// NEXT_HOP_INSTANCE_HAS_NO_IPV6_INTERFACE: The route's nextHopInstance URL
// refers to an instance that does not have an ipv6 interface on the same
// network as the route.
// NEXT_HOP_INSTANCE_NOT_FOUND: The route's nextHopInstance URL refers to an
// instance that does not exist.
// NEXT_HOP_INSTANCE_NOT_ON_NETWORK: The route's nextHopInstance URL refers
// to an instance that is not on the same network as the route.
// NEXT_HOP_NOT_RUNNING: The route's next hop instance does not have a
// status of RUNNING.
// NOT_CRITICAL_ERROR: Error which is not critical. We decided to continue
// the process despite the mentioned error.
// NO_RESULTS_ON_PAGE: No results are present on a particular list page.
// PARTIAL_SUCCESS: Success is reported, but some results may be missing due
// to errors
// REQUIRED_TOS_AGREEMENT: The user attempted to use a resource that
// requires a TOS they have not accepted.
// RESOURCE_IN_USE_BY_OTHER_RESOURCE_WARNING: Warning that a resource is in
// use.
// RESOURCE_NOT_DELETED: One or more of the resources set to auto-delete
// could not be deleted because they were in use.
// SCHEMA_VALIDATION_IGNORED: When a resource schema validation is ignored.
// SINGLE_INSTANCE_PROPERTY_TEMPLATE: Instance template used in instance
// group manager is valid as such, but its application does not make a lot
// of sense, because it allows only single instance in instance group.
// UNDECLARED_PROPERTIES: When undeclared properties in the schema are
// present
// UNREACHABLE: A given scope cannot be reached.
optional string code = 1;
message DataItem {
// [Output Only] A key that provides more detail on the warning being
// returned. For example, for warnings where there are no results in a
// list request for a particular zone, this key might be scope and the key
// value might be the zone name. Other examples might be a key indicating
// a deprecated resource and a suggested replacement, or a warning about
// invalid network settings (for example, if an instance attempts to
// perform IP forwarding but is not enabled for IP forwarding).
optional string key = 1;
// [Output Only] A warning data value corresponding to the key.
optional string value = 2;
}
// [Output Only] Metadata about this warning in key: value format. For
// example: "data": [ { "key": "scope", "value": "zones/us-east1-d" }
repeated DataItem data = 2;
// [Output Only] A human-readable description of the warning code.
optional string message = 3;
}
// [Output Only] Informational warning message.
optional Warning warning = 6;
}
// Container for either a built-in LB policy supported by gRPC or Envoy or a
// custom one implemented by the end user.
message BackendServiceLocalityLoadBalancingPolicyConfig {
optional BackendServiceLocalityLoadBalancingPolicyConfigCustomPolicy
custom_policy = 1;
optional BackendServiceLocalityLoadBalancingPolicyConfigPolicy policy = 2;
}
// The configuration for a custom policy implemented by the user and deployed
// with the client.
message BackendServiceLocalityLoadBalancingPolicyConfigCustomPolicy {
// An optional, arbitrary JSON object with configuration data, understood by a
// locally installed custom policy implementation.
optional string data = 1;
// Identifies the custom policy. The value should match the name of a custom
// implementation registered on the gRPC clients. It should follow protocol
// buffer message naming conventions and include the full path (for example,
// myorg.CustomLbPolicy). The maximum length is 256 characters. Do not specify
// the same custom policy more than once for a backend. If you do, the
// configuration is rejected. For an example of how to use this field, see Use
// a custom policy.
optional string name = 2;
}
// The configuration for a built-in load balancing policy.
message BackendServiceLocalityLoadBalancingPolicyConfigPolicy {
// The name of a locality load-balancing policy. Valid values include
// ROUND_ROBIN and, for Java clients, LEAST_REQUEST. For information about
// these values, see the description of localityLbPolicy. Do not specify the
// same policy more than once for a backend. If you do, the configuration is
// rejected.
// INVALID_LB_POLICY:
// LEAST_REQUEST: An O(1) algorithm which selects two random healthy hosts and
// picks the host which has fewer active requests.
// MAGLEV: This algorithm implements consistent hashing to backends. Maglev
// can be used as a drop in replacement for the ring hash load balancer.
// Maglev is not as stable as ring hash but has faster table lookup build
// times and host selection times. For more information about Maglev, see
// https://ai.google/research/pubs/pub44824
// ORIGINAL_DESTINATION: Backend host is selected based on the client
// connection metadata, i.e., connections are opened to the same address as
// the destination address of the incoming connection before the connection
// was redirected to the load balancer.
// RANDOM: The load balancer selects a random healthy host.
// RING_HASH: The ring/modulo hash load balancer implements consistent hashing
// to backends. The algorithm has the property that the addition/removal of a
// host from a set of N hosts only affects 1/N of the requests.
// ROUND_ROBIN: This is a simple policy in which each healthy backend is
// selected in round robin order. This is the default.
// WEIGHTED_MAGLEV: Per-instance weighted Load Balancing via health check
// reported weights. If set, the Backend Service must configure a non legacy
// HTTP-based Health Check, and health check replies are expected to contain
// non-standard HTTP response header field X-Load-Balancing-Endpoint-Weight to
// specify the per-instance weights. If set, Load Balancing is weighted based
// on the per-instance weights reported in the last processed health check
// replies, as long as every instance either reported a valid weight or had
// UNAVAILABLE_WEIGHT. Otherwise, Load Balancing remains equal-weight. This
// option is only supported in Network Load Balancing.
optional string name = 1;
}
// The available logging options for the load balancer traffic served by this
// backend service.
message BackendServiceLogConfig {
// Denotes whether to enable logging for the load balancer traffic served by
// this backend service. The default value is false.
optional bool enable = 1;
// This field can only be specified if logging is enabled for this backend
// service and "logConfig.optionalMode" was set to CUSTOM. Contains a list of
// optional fields you want to include in the logs. For example:
// serverInstance, serverGkeDetails.cluster, serverGkeDetails.pod.podNamespace
repeated string optional_fields = 2;
// This field can only be specified if logging is enabled for this backend
// service. Configures whether all, none or a subset of optional fields should
// be added to the reported logs. One of [INCLUDE_ALL_OPTIONAL,
// EXCLUDE_ALL_OPTIONAL, CUSTOM]. Default is EXCLUDE_ALL_OPTIONAL.
// CUSTOM: A subset of optional fields.
// EXCLUDE_ALL_OPTIONAL: None optional fields.
// INCLUDE_ALL_OPTIONAL: All optional fields.
optional string optional_mode = 3;
// This field can only be specified if logging is enabled for this backend
// service. The value of the field must be in [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.
optional float sample_rate = 4;
}
// Message containing what to include in the cache key for a request for Cloud
// CDN.
message CacheKeyPolicy {
// If true, requests to different hosts will be cached separately.
optional bool include_host = 1;
// Allows HTTP request headers (by name) to be used in the cache key.
repeated string include_http_headers = 2;
// Allows HTTP cookies (by name) to be used in the cache key. The name=value
// pair will be used in the cache key Cloud CDN generates.
repeated string include_named_cookies = 3;
// If true, http and https requests will be cached separately.
optional bool include_protocol = 4;
// If true, include query string parameters in the cache key according to
// query_string_whitelist and query_string_blacklist. If neither is set, the
// entire query string will be included. If false, the query string will be
// excluded from the cache key entirely.
optional bool include_query_string = 5;
// Names of query string parameters to exclude in cache keys. All other
// parameters will be included. Either specify query_string_whitelist or
// query_string_blacklist, not both. '&' and '=' will be percent encoded and
// not treated as delimiters.
repeated string query_string_blacklist = 6;
// Names of query string parameters to include in cache keys. All other
// parameters will be excluded. Either specify query_string_whitelist or
// query_string_blacklist, not both. '&' and '=' will be percent encoded and
// not treated as delimiters.
repeated string query_string_whitelist = 7;
}
// Settings controlling the volume of requests, connections and retries to this
// backend service.
message CircuitBreakers {
// The maximum number of connections to the backend service. If not specified,
// there is no limit. Not supported when the backend service is referenced by
// a URL map that is bound to target gRPC proxy that has validateForProxyless
// field set to true.