feat: apply retry policy to read only grpc endpoints (#16085)

This commit is contained in:
Poonam Jadhav 2023-01-31 10:44:25 -05:00 committed by GitHub
parent 1b02749375
commit 9db5b7d896
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -37,8 +37,8 @@ import (
// - https://github.com/grpc/grpc/blob/master/doc/service_config.md // - https://github.com/grpc/grpc/blob/master/doc/service_config.md
// - https://github.com/grpc/grpc-proto/blob/master/grpc/service_config/service_config.proto // - https://github.com/grpc/grpc-proto/blob/master/grpc/service_config/service_config.proto
// //
// TODO(boxofrad): we can use the rate limit annotations to figure out which // TODO: these are hard-coded for now
// methods are reads (and therefore safe to retry whatever the status code). // but we're working on generating them automatically from the protobuf files
const grpcServiceConfig = ` const grpcServiceConfig = `
{ {
"loadBalancingConfig": [{"%s":{}}], "loadBalancingConfig": [{"%s":{}}],
@ -52,6 +52,79 @@ const grpcServiceConfig = `
"MaxBackoff": "5s", "MaxBackoff": "5s",
"RetryableStatusCodes": ["RESOURCE_EXHAUSTED"] "RetryableStatusCodes": ["RESOURCE_EXHAUSTED"]
} }
},
{
"name": [
{
"service": "hashicorp.consul.connectca.ConnectCAService",
"method": "WatchRoots"
},
{
"service": "hashicorp.consul.dataplane.DataplaneService",
"method": "GetEnvoyBootstrapParams"
},
{
"service": "hashicorp.consul.dataplane.DataplaneService",
"method": "GetSupportedDataplaneFeatures"
},
{
"service": "hashicorp.consul.dns.DNSService",
"method": "Query"
},
{
"service": "hashicorp.consul.internal.peering.PeeringService",
"method": "PeeringList"
},
{
"service": "hashicorp.consul.internal.peering.PeeringService",
"method": "PeeringRead"
},
{
"service": "hashicorp.consul.internal.peering.PeeringService",
"method": "TrustBundleListByService"
},
{
"service": "hashicorp.consul.internal.peering.PeeringService",
"method": "TrustBundleRead"
},
{
"service": "hashicorp.consul.internal.peerstream.PeerStreamService",
"method": "StreamResources"
},
{
"service": "hashicorp.consul.serverdiscovery.ServerDiscoveryService",
"method": "WatchServers"
},
{
"service": "subscribe.StateChangeSubscription",
"method": "Subscribe"
},
{
"service": "partition.PartitionService",
"method": "List"
},
{
"service": "partition.PartitionService",
"method": "Read"
}
],
"retryPolicy": {
"MaxAttempts": 5,
"BackoffMultiplier": 2,
"InitialBackoff": "1s",
"MaxBackoff": "5s",
"RetryableStatusCodes": [
"CANCELLED",
"UNKNOWN",
"DEADLINE_EXCEEDED",
"RESOURCE_EXHAUSTED",
"FAILED_PRECONDITION",
"ABORTED",
"OUT_OF_RANGE",
"INTERNAL",
"UNAVAILABLE"
]
}
} }
] ]
}` }`