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


Python eventlet.Timeout方法代碼示例

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


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

示例1: run

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def run(self):
        acceptors = []
        for sock in self.sockets:
            gsock = GreenSocket(sock)
            gsock.setblocking(1)
            hfun = partial(self.handle, gsock)
            acceptor = eventlet.spawn(_eventlet_serve, gsock, hfun,
                                      self.worker_connections)

            acceptors.append(acceptor)
            eventlet.sleep(0.0)

        while self.alive:
            self.notify()
            eventlet.sleep(1.0)

        self.notify()
        try:
            with eventlet.Timeout(self.cfg.graceful_timeout) as t:
                [a.kill(eventlet.StopServe()) for a in acceptors]
                [a.wait() for a in acceptors]
        except eventlet.Timeout as te:
            if te != t:
                raise
            [a.kill() for a in acceptors] 
開發者ID:jpush,項目名稱:jbox,代碼行數:27,代碼來源:geventlet.py

示例2: test_do_afxr_fails_with_timeout

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def test_do_afxr_fails_with_timeout(self, mock_cancel, mock_from_xfr,
                                        mock_xfr):
        mock_from_xfr.side_effect = eventlet.Timeout()

        masters = [
            {'host': '192.168.0.1', 'port': 53},
            {'host': '192.168.0.2', 'port': 53},
            {'host': '192.168.0.3', 'port': 53},
            {'host': '192.168.0.4', 'port': 53},
        ]

        self.assertRaises(
            exceptions.XFRFailure,
            dnsutils.do_axfr, 'example.com.', masters,
        )

        self.assertTrue(mock_xfr.called)
        self.assertTrue(mock_from_xfr.called)
        self.assertTrue(mock_cancel.called) 
開發者ID:openstack,項目名稱:designate,代碼行數:21,代碼來源:test_dnsutils.py

示例3: poll_response

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def poll_response(self, response):
        """
        The API might return a job nr in the response in case of a async
        response: https://github.com/fog/fog/issues/575
        """
        status = response.status

        timeout = Timeout(CONF[CFG_GROUP_NAME].job_timeout)
        try:
            while status == 307:
                time.sleep(1)
                url = response.headers.get('Location')
                LOG.debug("Polling %s", url)

                polled_response = self.get(url)
                status = response.status
        except Timeout as t:
            if t == timeout:
                raise DynTimeoutError('Timeout reached when pulling job.')
        finally:
            timeout.cancel()
        return polled_response 
開發者ID:openstack,項目名稱:designate,代碼行數:24,代碼來源:impl_dynect.py

示例4: evenlet_timeout_deco

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def evenlet_timeout_deco(timeout_t):
    def _evenlet_timeout_deco(f):
        def __evenlet_timeout_deco(*args, **kwargs):
            timeout = Timeout(timeout_t, )
            # timeout.start()  # 與gevent不一樣,直接start了。
            result = None
            try:
                result = f(*args, **kwargs)
            except Timeout as t:
                logger_evenlet_timeout_deco.error(f'函數 {f} 運行超過了 {timeout_t} 秒')
                if t is not timeout:
                    nb_print(t)
                    # raise  # not my timeout
            finally:
                timeout.cancel()
                return result

        return __evenlet_timeout_deco

    return _evenlet_timeout_deco 
開發者ID:ydf0509,項目名稱:distributed_framework,代碼行數:22,代碼來源:custom_evenlet_pool_executor.py

示例5: get_path

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def get_path(self, project_file=None):
        """Get the absolute path to a file. Used for testing the API.

        :param project_file: File whose path to return. Default: None.
        :returns: path to the specified file, or path to project root.
        """
        root = os.path.abspath(
            os.path.join(os.path.dirname(__file__), '..', '..')
            )
        if project_file:
            return os.path.join(root, project_file)
        else:
            return root


# Test worker cannot survive eventlet's Timeout exception, which effectively
# kills the whole worker, with all test cases scheduled to it. This metaclass
# makes all test cases convert Timeout exceptions into unittest friendly
# failure mode (self.fail). 
開發者ID:openstack,項目名稱:cyborg,代碼行數:21,代碼來源:base.py

示例6: test_PUT_timeout_during_data_transfer

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def test_PUT_timeout_during_data_transfer(self):
        """The gateway times out while upload data to the server."""
        class FakeReader(object):
            def read(self, size):
                raise Timeout()

        req = Request.blank('/v1/a/c/o.jpg', method='PUT',
                            body='test body')
        req.environ['wsgi.input'] = FakeReader()
        req.headers['content-length'] = '6'
        chunks = [{"url": "http://127.0.0.1:7000/AAAA", "pos": "0", "size": 6}]
        meta = fake_prepare_meta()
        self.storage.container.content_prepare = Mock(
            return_value=(meta, chunks))
        with patch('oio.api.replication.io.http_connect',
                   new=fake_http_connect):
            resp = req.get_response(self.app)
            self.assertEqual(503, resp.status_int) 
開發者ID:open-io,項目名稱:oio-swift,代碼行數:20,代碼來源:test_obj.py

示例7: execute_run

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def execute_run(self, exec_id, command):
        with docker_utils.docker_client() as docker:
            try:
                with eventlet.Timeout(CONF.docker.execute_timeout):
                    output = docker.exec_start(exec_id, False, False, False)
            except eventlet.Timeout:
                raise exception.Conflict(_(
                    "Timeout on executing command: %s") % command)
            inspect_res = docker.exec_inspect(exec_id)
            return output, inspect_res['ExitCode'] 
開發者ID:openstack,項目名稱:zun,代碼行數:12,代碼來源:driver.py

示例8: timeout_ctx

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def timeout_ctx(self):
        return eventlet.Timeout(self.cfg.keepalive or None, False) 
開發者ID:jpush,項目名稱:jbox,代碼行數:4,代碼來源:geventlet.py

示例9: Timeout

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def Timeout(self, timeout, raise_after=True):
        return eventlet.Timeout(timeout, raise_after) 
開發者ID:noisyboiler,項目名稱:wampy,代碼行數:4,代碼來源:eventlet_.py

示例10: receive_message

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def receive_message(self, timeout):
        try:
            message = self._wait_for_message(timeout)
        except eventlet.Timeout:
            raise WampyTimeOutError(
                "no message returned (timed-out in {})".format(timeout)
            )
        return message 
開發者ID:noisyboiler,項目名稱:wampy,代碼行數:10,代碼來源:eventlet_.py

示例11: _wait_for_message

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def _wait_for_message(self, timeout):
        q = self.message_queue

        with eventlet.Timeout(timeout):
            while q.qsize() == 0:
                eventlet.sleep()

        message = q.get()
        return message 
開發者ID:noisyboiler,項目名稱:wampy,代碼行數:11,代碼來源:eventlet_.py

示例12: __init__

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def __init__(self):
        super(TimeoutException, self).__init__('Timeout') 
開發者ID:openstack,項目名稱:dragonflow,代碼行數:4,代碼來源:app_testing_objects.py

示例13: wait

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def wait(self, timeout, exception):
        with eventlet.Timeout(timeout, exception):
            try:
                self.daemon.wait()
            except greenlet.GreenletExit:
                return True 
開發者ID:openstack,項目名稱:dragonflow,代碼行數:8,代碼來源:app_testing_objects.py

示例14: tara

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def tara(ip):
	try:
		with eventlet.Timeout(3):
			address = 'http://'+ip+':8545'
			data = {"jsonrpc":"2.0","method":"web3_clientVersion","params":[],"id":1}
			headers = {'Content-type': 'application/json', 'Accept': 'text/plain'}
			r = requests.post(address, data=json.dumps(data), headers=headers, timeout=3)
			return r.text
	except: 
	  pass 
開發者ID:tolgatasci,項目名稱:geth-hack,代碼行數:12,代碼來源:start.py

示例15: _as_timed_sync_func

# 需要導入模塊: import eventlet [as 別名]
# 或者: from eventlet import Timeout [as 別名]
def _as_timed_sync_func(self, sync_func, name, timeout):
        def _timed_sync():
            with eventlet.Timeout(
                timeout,
                exception=exception.ClusterDataModelCollectionError(cdm=name)
            ):
                sync_func()

        return _timed_sync 
開發者ID:openstack,項目名稱:watcher,代碼行數:11,代碼來源:scheduling.py


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