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


Python async_timeout.timeout方法代碼示例

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


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

示例1: _connect_sentinel

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def _connect_sentinel(self, address, timeout, pools):
        """Try to connect to specified Sentinel returning either
        connections pool or exception.
        """
        try:
            with async_timeout(timeout):
                pool = await create_pool(
                    address, minsize=1, maxsize=2,
                    parser=self._parser_class,
                    )
            pools.append(pool)
            return pool
        except asyncio.TimeoutError as err:
            sentinel_logger.debug(
                "Failed to connect to Sentinel(%r) within %ss timeout",
                address, timeout)
            return err
        except Exception as err:
            sentinel_logger.debug(
                "Error connecting to Sentinel(%r): %r", address, err)
            return err 
開發者ID:aio-libs,項目名稱:aioredis,代碼行數:23,代碼來源:pool.py

示例2: test_create_no_minsize

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def test_create_no_minsize(create_pool, server):
    pool = await create_pool(
        server.tcp_address,
        minsize=0, maxsize=1)
    assert pool.size == 0
    assert pool.freesize == 0

    with (await pool):
        assert pool.size == 1
        assert pool.freesize == 0

        with pytest.raises(asyncio.TimeoutError):
            await asyncio.wait_for(pool.acquire(),
                                   timeout=0.2)
    assert pool.size == 1
    assert pool.freesize == 1 
開發者ID:aio-libs,項目名稱:aioredis,代碼行數:18,代碼來源:pool_test.py

示例3: RPCContext

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def RPCContext(addr, timeout=None, *, order_key: str = None):
    global agent_peers
    peer = agent_peers.get(addr, None)
    if peer is None:
        peer = PeerInvoker(
            connect=ZeroMQAddress(addr),
            transport=ZeroMQRPCTransport,
            serializer=msgpack.packb,
            deserializer=msgpack.unpackb,
        )
        await peer.__aenter__()
        agent_peers[addr] = peer
    try:
        with _timeout(timeout):
            okey_token = peer.call.order_key.set('')
            try:
                yield peer
            finally:
                peer.call.order_key.reset(okey_token)
    except RPCUserError as orig_exc:
        raise AgentError(orig_exc.name, orig_exc.args)
    except Exception:
        raise 
開發者ID:lablup,項目名稱:backend.ai-manager,代碼行數:25,代碼來源:registry.py

示例4: check_agent_lost

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def check_agent_lost(app, interval):
    try:
        now = datetime.now(tzutc())
        timeout = timedelta(seconds=app['config']['manager']['heartbeat-timeout'])

        async def _check_impl():
            async for agent_id, prev in app['redis_live'].ihscan('last_seen'):
                prev = datetime.fromtimestamp(float(prev), tzutc())
                if now - prev > timeout:
                    await app['event_dispatcher'].produce_event(
                        'instance_terminated', ('agent-lost', ),
                        agent_id=agent_id)

        await redis.execute_with_retries(lambda: _check_impl())
    except asyncio.CancelledError:
        pass


# NOTE: This event is ignored during the grace period. 
開發者ID:lablup,項目名稱:backend.ai-manager,代碼行數:21,代碼來源:session.py

示例5: __init__

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def __init__(self,
                 client,
                 session=None,
                 loads=data_processing.loads,
                 timeout=10,
                 **kwargs):

        self.client = client
        self.session = session
        self.loads = loads
        self.timeout = timeout
        self.kwargs = kwargs

        self.response = None
        self._reconnecting = False
        self._state = NORMAL
        self._error_timeout = 0 
開發者ID:odrling,項目名稱:peony-twitter,代碼行數:19,代碼來源:stream.py

示例6: _connect

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def _connect(self):
        """
            Connect to the stream

        Returns
        -------
        asyncio.coroutine
            The streaming response
        """
        logger.debug("connecting to the stream")
        await self.client.setup
        if self.session is None:
            self.session = self.client._session
        kwargs = await self.client.headers.prepare_request(**self.kwargs)
        request = self.client.error_handler(self.session.request)

        return await request(timeout=0, **kwargs) 
開發者ID:odrling,項目名稱:peony-twitter,代碼行數:19,代碼來源:stream.py

示例7: test_stream_reconnection_enhance_your_calm

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def test_stream_reconnection_enhance_your_calm():
    async def dummy(*args, **kwargs):
        pass

    turn = -1

    async with Stream() as stream:
        with patch.object(stream, '_connect', side_effect=response_calm):
            with patch.object(peony.stream.asyncio, 'sleep',
                              side_effect=dummy):
                async for data in stream:
                    assert stream._state == ENHANCE_YOUR_CALM
                    turn += 1

                    if turn >= 100:
                        break

                    if turn == 0:
                        assert data == {'connected': True}
                    elif turn % 2 == 1:
                        timeout = ENHANCE_YOUR_CALM_TIMEOUT * 2**(turn // 2)
                        assert data == {'reconnecting_in': timeout,
                                        'error': None}
                    else:
                        assert data == {'stream_restart': True} 
開發者ID:odrling,項目名稱:peony-twitter,代碼行數:27,代碼來源:test_stream.py

示例8: test_stream_cancel

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def test_stream_cancel(event_loop):
    async def cancel(task):
        await asyncio.sleep(0.001)
        task.cancel()

    async def test_stream_iterations(stream):
        async with async_timeout.timeout(0.5):
            while True:
                await _stream_iteration(stream)

    async with aiohttp.ClientSession() as session:
        client = peony.client.BasePeonyClient("", "", session=session)
        context = peony.stream.StreamResponse(method='GET',
                                              url="http://whatever.com",
                                              client=client)

        with context as stream:
            with patch.object(stream, '_connect',
                              side_effect=stream_content):
                coro = test_stream_iterations(stream)
                task = event_loop.create_task(coro)
                cancel_task = event_loop.create_task(cancel(task))

                with async_timeout.timeout(1):
                    await asyncio.wait([task, cancel_task]) 
開發者ID:odrling,項目名稱:peony-twitter,代碼行數:27,代碼來源:test_stream.py

示例9: _download_file

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def _download_file(self, url, name):
        """Async file download

        Args:
            url (str):
                The URL from which to download the file
            name (str):
                The name to give to the downloaded file
        """
        with async_timeout.timeout(10):
            async with self.api.session.get(url) as response:
                filename = os.path.basename(name)
                with open(filename, 'wb') as f_handle:
                    while True:
                        chunk = await response.content.read(1024)
                        if not chunk:
                            break
                        f_handle.write(chunk)
                return await response.release() 
開發者ID:jgayfer,項目名稱:pydest,代碼行數:21,代碼來源:manifest.py

示例10: test_rpc_call

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def test_rpc_call(
    rpc_client_factory,
    rpc_server_close,
    amqp_queue_name,
):
    fut = asyncio.Future()

    @RpcMethod.init(amqp_queue_name)
    async def test_method():
        fut.set_result(True)

    await rpc_server_close(test_method, amqp_queue_name)

    client = await rpc_client_factory()

    resp = await client.call(test_method())

    assert resp is None

    assert not client._map

    await client.close()

    async with timeout(0.1):
        assert await fut 
開發者ID:aio-libs,項目名稱:aioamqp_consumer,代碼行數:27,代碼來源:test_rpc.py

示例11: test_rpc_timeout

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def test_rpc_timeout(
    rpc_client_close,
    rpc_server_close,
    amqp_queue_name,
):
    fut = asyncio.Future()

    @RpcMethod.init(amqp_queue_name)
    async def test_method():
        await asyncio.sleep(0.2)
        fut.set_result(True)

    server = await rpc_server_close(test_method, amqp_queue_name)

    client = await rpc_client_close()

    with pytest.raises(asyncio.TimeoutError):
        await client.wait(test_method(), timeout=0.1)

    await server.join()

    async with timeout(0.2):
        assert await fut 
開發者ID:aio-libs,項目名稱:aioamqp_consumer,代碼行數:25,代碼來源:test_rpc.py

示例12: transfer_info

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def transfer_info(self):
        ret_zones = list()
        try:
            nss = dns.resolver.query(self.domain, 'NS')
            nameservers = [str(ns) for ns in nss]
            ns_addr = dns.resolver.query(nameservers[0], 'A')
            # dnspython 的 bug,需要設置 lifetime 參數
            zones = dns.zone.from_xfr(dns.query.xfr(ns_addr, self.domain, relativize=False, timeout=2, lifetime=2), check_origin=False)
            names = zones.nodes.keys()
            for n in names:
                subdomain = ''
                for t in range(0, len(n) - 1):
                    if subdomain != '':
                        subdomain += '.'
                    subdomain += str(n[t].decode())
                if subdomain != self.domain:
                    ret_zones.append(subdomain)
            return ret_zones
        except BaseException:
            return [] 
開發者ID:FeeiCN,項目名稱:ESD,代碼行數:22,代碼來源:__init__.py

示例13: search

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def search(self):
        result = list()
        url = self.base_url.format(email=self.email, key=self.fkey, domain=self.domain)
        try:
            resp = requests.Session().get(url, headers=self.headers, timeout=self.timeout)
            json_resp = json.loads(resp.text)
            for res in json_resp['results']:
                domain = urlparse.urlparse(res[0]).netloc
                result.append(domain.rsplit(self.domain, 1)[0].strip('.'))
        except Exception as e:
            result = []

        return result


# Zoomeye的效果還可以,但是比fofa還貴 
開發者ID:FeeiCN,項目名稱:ESD,代碼行數:18,代碼來源:__init__.py

示例14: enumerate

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def enumerate(self):
        flag = True
        num = 1
        result = list()
        while flag:
            response = self.search(num)
            if response is None or 'error' in response.keys():
                # print(response)
                flag = False
            else:
                match_list = response["matches"]
                for block in match_list:
                    domain = block['site']
                    result.append(domain.rsplit(self.domain, 1)[0].strip('.'))
                num = num + 1
        return result


# censys的接口有點不穩定,經常出現timeout的情況 
開發者ID:FeeiCN,項目名稱:ESD,代碼行數:21,代碼來源:__init__.py

示例15: __init__

# 需要導入模塊: import async_timeout [as 別名]
# 或者: from async_timeout import timeout [as 別名]
def __init__(self, base_url, domain, q, verbose, proxy):
        multiprocessing.Process.__init__(self)
        self.lock = threading.Lock()
        self.q = q
        self.subdomains = []
        self.base_url = base_url
        self.domain = domain
        self.session = requests.Session()
        self.headers = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.36',
            'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',
            'Accept-Language': 'en-US,en;q=0.8',
            'Accept-Encoding': 'gzip',
        }
        self.timeout = 30
        self.verbose = verbose
        self.proxy = proxy 
開發者ID:FeeiCN,項目名稱:ESD,代碼行數:19,代碼來源:__init__.py


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