當前位置: 首頁>>代碼示例>>Python>>正文


Python grpc.channel_ready_future方法代碼示例

本文整理匯總了Python中grpc.channel_ready_future方法的典型用法代碼示例。如果您正苦於以下問題:Python grpc.channel_ready_future方法的具體用法?Python grpc.channel_ready_future怎麽用?Python grpc.channel_ready_future使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在grpc的用法示例。


在下文中一共展示了grpc.channel_ready_future方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: ping

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def ping(self, timeout=30):
        ft = grpc.channel_ready_future(self._channel)
        retry = self._max_retry
        try:
            while retry > 0:
                try:
                    ft.result(timeout=timeout)
                    return True
                except:
                    retry -= 1
                    LOGGER.debug("Retry connect addr <{}> {} times".format(self._uri, self._max_retry - retry))
                    if retry > 0:
                        continue
                    else:
                        LOGGER.error("Retry to connect server {} failed.".format(self._uri))
                        raise
        except grpc.FutureTimeoutError:
            raise NotConnectError('Fail connecting to server on {}. Timeout'.format(self._uri))
        except grpc.RpcError as e:
            raise NotConnectError("Connect error: <{}>".format(e))
        # Unexpected error
        except Exception as e:
            raise NotConnectError("Error occurred when trying to connect server:\n"
                                  "\t<{}>".format(str(e))) 
開發者ID:milvus-io,項目名稱:pymilvus,代碼行數:26,代碼來源:grpc_handler.py

示例2: run

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def run():
    channel = grpc.insecure_channel('localhost:50051')
    try:
        grpc.channel_ready_future(channel).result(timeout=10)
    except grpc.FutureTimeoutError:
        sys.exit('Error connecting to server')
    else:
        stub = users_service.UsersStub(channel)
        metadata = [('ip', '127.0.0.1')]
        response = stub.CreateUser(
            users_messages.CreateUserRequest(username='tom'),
            metadata=metadata,
        )
        if response:
            print("User created:", response.user.username)
        request = users_messages.GetUsersRequest(
            user=[users_messages.User(username="alexa", user_id=1),
                  users_messages.User(username="christie", user_id=1)]
        )
        response = stub.GetUsers(request, timeout=0.00001)
        for resp in response:
            print(resp) 
開發者ID:amitsaha,項目名稱:python-grpc-demo,代碼行數:24,代碼來源:sample_client_demo_timeout.py

示例3: run

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def run():
    channel = grpc.insecure_channel('localhost:50051')
    try:
        grpc.channel_ready_future(channel).result(timeout=10)
    except grpc.FutureTimeoutError:
        sys.exit('Error connecting to server')
    else:
        stub = users_service.UsersStub(channel)
        metadata = [('ip', '127.0.0.1')]
        response = stub.CreateUser(
            users_messages.CreateUserRequest(username='tom'),
            metadata=metadata,
        )
        if response:
            print("User created:", response.user.username)
        request = users_messages.GetUsersRequest(
            user=[users_messages.User(username="alexa", user_id=1),
                  users_messages.User(username="christie", user_id=1)]
        )
        response = stub.GetUsers(request)
        for resp in response:
            print(resp) 
開發者ID:amitsaha,項目名稱:python-grpc-demo,代碼行數:24,代碼來源:sample_client_demo.py

示例4: connect

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def connect(cls, datadir, jarfile):
        # Check for running server instances
        jar = os.path.split(jarfile)[-1]
        for p in psutil.process_iter(attrs = ["name", "cmdline"]):
            if (p.info["name"] == "java" and
                any(x.endswith(jar) for x in p.info["cmdline"])):
                return

        # Start server
        cmdline = ["java", "-Xmx2G", "-XX:+UseG1GC", "-jar",
                   jarfile, str(cls.rpc_port), datadir]
        cls.rpc_server_proc = psutil.Popen(cmdline)

        atexit.register(RemoteServer.disconnect)
        with grpc.insecure_channel(cls.rpc_uri) as chan:
            grpc.channel_ready_future(chan).result(timeout = 60.0) 
開發者ID:ut-astria,項目名稱:orbdetpy,代碼行數:18,代碼來源:server.py

示例5: reset

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def reset(self):
    if self._channel is not None:
      # Client surrenders in the current game and starts next one.

      self._channel.close()
      self._channel = None

    # Get game server address and side id from master.
    start_game_request = master_pb2.StartGameRequest(
        game_version=config.game_version, username=self._username,
        token=self._token, model_name=self._model_name,
        include_rendering=self._include_rendering)
    response = self._reset_with_retries(start_game_request)
    self._game_id = response.game_id
    self._channel = utils.get_grpc_channel(response.game_server_address)
    grpc.channel_ready_future(self._channel).result()
    get_env_result_request = game_server_pb2.GetEnvResultRequest(
        game_version=config.game_version, game_id=self._game_id,
        username=self._username, token=self._token, model_name=self._model_name)
    return self._get_env_result(get_env_result_request, 'GetEnvResult')[0] 
開發者ID:google-research,項目名稱:football,代碼行數:22,代碼來源:remote_football_env.py

示例6: user_authentication

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def user_authentication(session_id: bytes, cert: bytes, ip: str, name: str) -> str:
    # Pin the robot certificate for opening the channel
    creds = grpc.ssl_channel_credentials(root_certificates=cert)

    print("Attempting to download guid from {} at {}:443...".format(
        colored(name, "cyan"), colored(ip, "cyan")), end="")
    sys.stdout.flush()
    channel = grpc.secure_channel("{}:443".format(ip), creds,
                                  options=(("grpc.ssl_target_name_override", name,),))

    # Verify the connection to Vector is able to be established (client-side)
    try:
        # Explicitly grab _channel._channel to test the underlying grpc channel directly
        grpc.channel_ready_future(channel).result(timeout=15)
    except grpc.FutureTimeoutError:
        print(colored(" ERROR", "red"))
        sys.exit("\nUnable to connect to Vector\n"
                 "Please be sure to connect via the Vector companion app first, and connect your computer to the same network as your Vector.")

    try:
        interface = messaging.client.ExternalInterfaceStub(channel)
        request = messaging.protocol.UserAuthenticationRequest(
            user_session_id=session_id.encode('utf-8'),
            client_name=socket.gethostname().encode('utf-8'))
        response = interface.UserAuthentication(request)
        if response.code != messaging.protocol.UserAuthenticationResponse.AUTHORIZED:  # pylint: disable=no-member
            print(colored(" ERROR", "red"))
            sys.exit("\nFailed to authorize request:\n"
                     "Please be sure to first set up Vector using the companion app.")
    except grpc.RpcError as e:
        print(colored(" ERROR", "red"))
        sys.exit("\nFailed to authorize request:\n"
                 "An unknown error occurred '{}'".format(e))

    print(colored(" DONE\n", "green"))
    return response.client_token_guid 
開發者ID:rmountjoy92,項目名稱:VectorCloud,代碼行數:38,代碼來源:configure.py

示例7: _check_grpc_channel_ready

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def _check_grpc_channel_ready(channel):
  """Helper function to check the gRPC channel is ready N times."""
  for _ in range(_MAX_CONNECTION_ATTEMPTS - 1):
    try:
      return grpc.channel_ready_future(channel).result(timeout=1)
    except grpc.FutureTimeoutError:
      pass
  return grpc.channel_ready_future(channel).result(timeout=1) 
開發者ID:deepmind,項目名稱:dm_memorytasks,代碼行數:10,代碼來源:_load_environment.py

示例8: run

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def run():
    # read in certificate
    with open('server.crt') as f:
        trusted_certs = f.read().encode()

    # create credentials
    credentials = grpc.ssl_channel_credentials(root_certificates=trusted_certs)
    channel = grpc.secure_channel('localhost:50051', credentials)
    try:
        grpc.channel_ready_future(channel).result(timeout=10)
    except grpc.FutureTimeoutError:
        sys.exit('Error connecting to server')
    else:
        stub = users_service.UsersStub(channel)
        metadata = [('ip', '127.0.0.1')]

        try:
            response = stub.CreateUser(
                users_messages.CreateUserRequest(username='tom'),
                metadata=metadata,
            )
        except grpc.RpcError as e:
            print('CreateUser failed with {0}: {1}'.format(e.code(), e.details()))
        else:
            print("User created:", response.user.username)

        request = users_messages.GetUsersRequest(
            user=[users_messages.User(username="alexa", user_id=1),
                  users_messages.User(username="christie", user_id=1)]
        )
        response = stub.GetUsers(request)
        for resp in response:
            print(resp) 
開發者ID:amitsaha,項目名稱:python-grpc-demo,代碼行數:35,代碼來源:sample_client_demo.py

示例9: __init__

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def __init__(self, service_module, stub_name, host, port, timeout=10):
        channel = grpc.insecure_channel('{0}:{1}'.format(host, port))
        try:
            grpc.channel_ready_future(channel).result(timeout=10)
        except grpc.FutureTimeoutError:
            sys.exit('Error connecting to server')
        self.stub = getattr(service_module, stub_name)(channel)
        self.timeout = timeout 
開發者ID:amitsaha,項目名稱:python-grpc-demo,代碼行數:10,代碼來源:client_wrapper.py

示例10: _report_join

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def _report_join(self, ips):
        for ip in ips:
            channel = grpc.insecure_channel(
                "{ip}:{port}".format(ip=ip, port=self._port)
            )
            try:
                grpc.channel_ready_future(channel).result(timeout=2)
            except Exception as e:
                logging.warning(str(e))
                return False
            else:
                stub = communicate_pb2_grpc.ReportStub(channel)
            try:
                response = stub.GetGroupStatus(
                    communicate_pb2.GroupStatusRequest(), timeout=2
                )
            except Exception as e:
                logging.warning(str(e))
            else:
                logging.info("counter retreived")
                self._count = response.counter
                self._io_tool.register_ip(
                    SharedStorage.ip_address, self._count
                )
                return True
        logging.warning("counter not retreived")
        self._io_tool.register_ip(SharedStorage.ip_address, self._count)
        return False 
開發者ID:caicloud,項目名稱:ftlib,代碼行數:30,代碼來源:impl.py

示例11: _update_master

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def _update_master(self):
    while True:
      try:
        master_address = utils.get_master_address(self._track)
        logging.info('Connecting to %s', master_address)
        self._master_channel = utils.get_grpc_channel(master_address)
        grpc.channel_ready_future(self._master_channel).result(timeout=10)
        break
      except grpc.FutureTimeoutError:
        logging.info('Failed to connect to master')
      except BaseException as e:
        logging.info('Error %s, sleeping 10 secs', e)
        time.sleep(10)
    logging.info('Connection successful') 
開發者ID:google-research,項目名稱:football,代碼行數:16,代碼來源:remote_football_env.py

示例12: main

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def main(config):
    """Train an ES policy."""
    if config.run_on_gke:
        servers = ['{}'.format(addr)
                   for addr in config.server_addresses.split(',')]
    else:
        servers = ['127.0.0.1:{}'.format(config.server_port + i)
                   for i in range(config.num_workers)]
    print(servers)
    stubs = []
    for server in servers:
        if config.run_on_gke:
            channel = grpc.insecure_channel(
                server, [('grpc.lb_policy_name', 'round_robin')])
        else:
            channel = grpc.insecure_channel(server)
        grpc.channel_ready_future(channel).result()
        stubs.append(evaluation_service_pb2_grpc.RolloutStub(channel))

    learner.ESLearner(
        logdir=config.logdir,
        config=config.config,
        stubs=stubs,
    ).train()

    # This is to prevent GKE from restarting pod when the job finishes.
    if config.run_on_gke:
        try:
            while True:
                time.sleep(_ONE_DAY_IN_SECONDS)
        except KeyboardInterrupt:
            print('Job done.') 
開發者ID:lerrytang,項目名稱:es_on_gke,代碼行數:34,代碼來源:es_master.py

示例13: do_state_init

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def do_state_init(self, event):
        # Initialize gRPC
        self.channel = grpc.insecure_channel(self.host_and_port)
        self.channel_ready_future = grpc.channel_ready_future(self.channel)

        self.log.info('openolt-device-created') 
開發者ID:opencord,項目名稱:voltha,代碼行數:8,代碼來源:openolt_device.py

示例14: set_uri

# 需要導入模塊: import grpc [as 別名]
# 或者: from grpc import channel_ready_future [as 別名]
def set_uri(host, port, uri):
    if host is not None:
        _port = port if port is not None else config.GRPC_PORT
        _host = host
    elif port is None:
        try:
            _uri = urlparse(uri) if uri else urlparse(config.GRPC_URI)
            _host = _uri.hostname
            _port = _uri.port
        except (AttributeError, ValueError, TypeError) as e:
            raise ParamError("uri is illegal: {}".format(e))
    else:
        raise ParamError("Param is not complete. Please invoke as follow:\n"
                         "\t(host = ${HOST}, port = ${PORT})\n"
                         "\t(uri = ${URI})\n")

    if not is_legal_host(_host) or not is_legal_port(_port):
        raise ParamError("host or port is illeagl")

    return "{}:{}".format(str(_host), str(_port))


# def connect(addr, timeout):
#     channel = grpc.insecure_channel(
#         addr,
#         options=[(cygrpc.ChannelArgKey.max_send_message_length, -1),
#                  (cygrpc.ChannelArgKey.max_receive_message_length, -1)]
#     )
#     try:
#         ft = grpc.channel_ready_future(channel)
#         ft.result(timeout=timeout)
#         return True
#     except grpc.FutureTimeoutError:
#         raise NotConnectError('Fail connecting to server on {}. Timeout'.format(addr))
#     except grpc.RpcError as e:
#         raise NotConnectError("Connect error: <{}>".format(e))
#     # Unexpected error
#     except Exception as e:
#         raise NotConnectError("Error occurred when trying to connect server:\n"
#                               "\t<{}>".format(str(e)))
#     finally:
#         ft.cancel()
#         ft.__del__()
#         channel.__del__() 
開發者ID:milvus-io,項目名稱:pymilvus,代碼行數:46,代碼來源:grpc_handler.py


注:本文中的grpc.channel_ready_future方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。