You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

debugger_online_server.py 2.5 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. # Copyright 2021 Huawei Technologies Co., Ltd
  2. #
  3. # Licensed under the Apache License, Version 2.0 (the "License");
  4. # you may not use this file except in compliance with the License.
  5. # You may obtain a copy of the License at
  6. #
  7. # http://www.apache.org/licenses/LICENSE-2.0
  8. #
  9. # Unless required by applicable law or agreed to in writing, software
  10. # distributed under the License is distributed on an "AS IS" BASIS,
  11. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. # See the License for the specific language governing permissions and
  13. # limitations under the License.
  14. # ============================================================================
  15. """Debugger Online server."""
  16. from concurrent import futures
  17. import grpc
  18. from mindinsight.debugger.common.log import LOGGER as log
  19. from mindinsight.conf import settings
  20. from mindinsight.debugger.debugger_services.debugger_grpc_server import DebuggerGrpcServer
  21. from mindinsight.debugger.debugger_services.debugger_server_base import DebuggerServerBase
  22. from mindinsight.debugger.proto import debug_grpc_pb2_grpc as grpc_server_base
  23. def get_debugger_hostname():
  24. """Get hostname for online debugger server."""
  25. grpc_port = settings.DEBUGGER_PORT if hasattr(settings, 'DEBUGGER_PORT') else 50051
  26. host = settings.HOST if hasattr(settings, 'HOST') else '[::]'
  27. hostname = "{}:{}".format(host, grpc_port)
  28. return hostname
  29. class DebuggerOnlineServer(DebuggerServerBase):
  30. """Debugger Online Server."""
  31. def __init__(self, cache_store, context):
  32. super(DebuggerOnlineServer, self).__init__(cache_store, context)
  33. self._grpc_server_manager = self.get_grpc_server_manager()
  34. def run(self):
  35. self._grpc_server_manager.start()
  36. log.info("Start grpc server %s", self._context.hostname)
  37. self._grpc_server_manager.wait_for_termination()
  38. def get_grpc_server_manager(self):
  39. """Get grpc server instance according to hostname."""
  40. if self._context.hostname is None:
  41. self._context.hostname = get_debugger_hostname()
  42. grpc_server = DebuggerGrpcServer(self._cache_store, None)
  43. grpc_server_manager = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
  44. grpc_server_base.add_EventListenerServicer_to_server(grpc_server, grpc_server_manager)
  45. grpc_server_manager.add_insecure_port(self._context.hostname)
  46. return grpc_server_manager
  47. def stop(self):
  48. self._grpc_server_manager.stop(grace=None)
  49. self.join()