xref: /aosp_15_r20/external/grpc-grpc/examples/python/retry/retry_client.py (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
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