1*cc02d7e2SAndroid Build Coastguard Worker# Copyright 2021 The gRPC Authors 2*cc02d7e2SAndroid Build Coastguard Worker# 3*cc02d7e2SAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 4*cc02d7e2SAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 5*cc02d7e2SAndroid Build Coastguard Worker# You may obtain a copy of the License at 6*cc02d7e2SAndroid Build Coastguard Worker# 7*cc02d7e2SAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 8*cc02d7e2SAndroid Build Coastguard Worker# 9*cc02d7e2SAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 10*cc02d7e2SAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, 11*cc02d7e2SAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*cc02d7e2SAndroid Build Coastguard Worker# See the License for the specific language governing permissions and 13*cc02d7e2SAndroid Build Coastguard Worker# limitations under the License. 14*cc02d7e2SAndroid Build Coastguard Worker"""The Python implementation of the gRPC client-side retry example.""" 15*cc02d7e2SAndroid Build Coastguard Worker 16*cc02d7e2SAndroid Build Coastguard Workerimport json 17*cc02d7e2SAndroid Build Coastguard Workerimport logging 18*cc02d7e2SAndroid Build Coastguard Worker 19*cc02d7e2SAndroid Build Coastguard Workerimport grpc 20*cc02d7e2SAndroid Build Coastguard Worker 21*cc02d7e2SAndroid Build Coastguard Workerhelloworld_pb2, helloworld_pb2_grpc = grpc.protos_and_services( 22*cc02d7e2SAndroid Build Coastguard Worker "helloworld.proto" 23*cc02d7e2SAndroid Build Coastguard Worker) 24*cc02d7e2SAndroid Build Coastguard Worker 25*cc02d7e2SAndroid Build Coastguard Worker 26*cc02d7e2SAndroid Build Coastguard Workerdef run(): 27*cc02d7e2SAndroid Build Coastguard Worker # The ServiceConfig proto definition can be found: 28*cc02d7e2SAndroid Build Coastguard Worker # https://github.com/grpc/grpc-proto/blob/ec886024c2f7b7f597ba89d5b7d60c3f94627b17/grpc/service_config/service_config.proto#L377 29*cc02d7e2SAndroid Build Coastguard Worker service_config_json = json.dumps( 30*cc02d7e2SAndroid Build Coastguard Worker { 31*cc02d7e2SAndroid Build Coastguard Worker "methodConfig": [ 32*cc02d7e2SAndroid Build Coastguard Worker { 33*cc02d7e2SAndroid Build Coastguard Worker # To apply retry to all methods, put [{}] in the "name" field 34*cc02d7e2SAndroid Build Coastguard Worker "name": [ 35*cc02d7e2SAndroid Build Coastguard Worker {"service": "helloworld.Greeter", "method": "SayHello"} 36*cc02d7e2SAndroid Build Coastguard Worker ], 37*cc02d7e2SAndroid Build Coastguard Worker "retryPolicy": { 38*cc02d7e2SAndroid Build Coastguard Worker "maxAttempts": 5, 39*cc02d7e2SAndroid Build Coastguard Worker "initialBackoff": "0.1s", 40*cc02d7e2SAndroid Build Coastguard Worker "maxBackoff": "1s", 41*cc02d7e2SAndroid Build Coastguard Worker "backoffMultiplier": 2, 42*cc02d7e2SAndroid Build Coastguard Worker "retryableStatusCodes": ["UNAVAILABLE"], 43*cc02d7e2SAndroid Build Coastguard Worker }, 44*cc02d7e2SAndroid Build Coastguard Worker } 45*cc02d7e2SAndroid Build Coastguard Worker ] 46*cc02d7e2SAndroid Build Coastguard Worker } 47*cc02d7e2SAndroid Build Coastguard Worker ) 48*cc02d7e2SAndroid Build Coastguard Worker options = [] 49*cc02d7e2SAndroid Build Coastguard Worker # NOTE: the retry feature will be enabled by default >=v1.40.0 50*cc02d7e2SAndroid Build Coastguard Worker options.append(("grpc.enable_retries", 1)) 51*cc02d7e2SAndroid Build Coastguard Worker options.append(("grpc.service_config", service_config_json)) 52*cc02d7e2SAndroid Build Coastguard Worker with grpc.insecure_channel("localhost:50051", options=options) as channel: 53*cc02d7e2SAndroid Build Coastguard Worker stub = helloworld_pb2_grpc.GreeterStub(channel) 54*cc02d7e2SAndroid Build Coastguard Worker response = stub.SayHello(helloworld_pb2.HelloRequest(name="you")) 55*cc02d7e2SAndroid Build Coastguard Worker print("Greeter client received: " + response.message) 56*cc02d7e2SAndroid Build Coastguard Worker 57*cc02d7e2SAndroid Build Coastguard Worker 58*cc02d7e2SAndroid Build Coastguard Workerif __name__ == "__main__": 59*cc02d7e2SAndroid Build Coastguard Worker logging.basicConfig() 60*cc02d7e2SAndroid Build Coastguard Worker run() 61