| # Copyright 2023 gRPC authors. |
| # |
| # 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 |
| # |
| # http://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. |
| """The Python implementation of the GRPC helloworld.Greeter server with health checking.""" |
| |
| from concurrent import futures |
| import logging |
| import threading |
| from time import sleep |
| |
| import grpc |
| from grpc_health.v1 import health |
| from grpc_health.v1 import health_pb2 |
| from grpc_health.v1 import health_pb2_grpc |
| import helloworld_pb2 |
| import helloworld_pb2_grpc |
| |
| |
| class Greeter(helloworld_pb2_grpc.GreeterServicer): |
| def SayHello(self, request, context): |
| return helloworld_pb2.HelloReply(message=request.name) |
| |
| |
| def _toggle_health(health_servicer: health.HealthServicer, service: str): |
| next_status = health_pb2.HealthCheckResponse.SERVING |
| while True: |
| if next_status == health_pb2.HealthCheckResponse.SERVING: |
| next_status = health_pb2.HealthCheckResponse.NOT_SERVING |
| else: |
| next_status = health_pb2.HealthCheckResponse.SERVING |
| |
| health_servicer.set(service, next_status) |
| sleep(5) |
| |
| |
| def _configure_health_server(server: grpc.Server): |
| health_servicer = health.HealthServicer( |
| experimental_non_blocking=True, |
| experimental_thread_pool=futures.ThreadPoolExecutor(max_workers=10), |
| ) |
| health_pb2_grpc.add_HealthServicer_to_server(health_servicer, server) |
| |
| # Use a daemon thread to toggle health status |
| toggle_health_status_thread = threading.Thread( |
| target=_toggle_health, |
| args=(health_servicer, "helloworld.Greeter"), |
| daemon=True, |
| ) |
| toggle_health_status_thread.start() |
| |
| |
| def serve(): |
| port = "50051" |
| server = grpc.server(futures.ThreadPoolExecutor(max_workers=10)) |
| helloworld_pb2_grpc.add_GreeterServicer_to_server(Greeter(), server) |
| server.add_insecure_port("[::]:" + port) |
| _configure_health_server(server) |
| server.start() |
| print("Server started, listening on " + port) |
| server.wait_for_termination() |
| |
| |
| if __name__ == "__main__": |
| logging.basicConfig() |
| serve() |