【发布时间】:2018-04-17 04:08:13
【问题描述】:
我正在尝试同时请求一堆 URL,但是这些 URL 是从列表中构建的。目前我正在遍历列表并(我认为)将它们添加到队列中。它绝对比 requests.get 快 10 倍,但是我不确定我是否正确执行此操作,因此可以对其进行优化。我对其进行了分析,并注意到它在并发请求完成后仍有 90% 的时间处于锁定状态,即开始 -> 10+ 个并发请求 -> 锁定 5 秒左右 -> 完成
此外,此代码最后会生成 Unclosed client session 消息。知道为什么吗?很确定这是正确使用上下文管理器。
我已经搜索并没有找到这个确切的问题
import signal
import sys
import asyncio
import aiohttp
import json
import requests
lists = ['eth', 'btc', 'xmr', 'req', 'xlm', 'etc', 'omg', 'neo', 'btc', 'xmr', 'req', 'xlm', 'etc', 'omg', 'neo']
loop = asyncio.get_event_loop()
client = aiohttp.ClientSession(loop=loop)
async def fetch(client, url):
async with client.get(url) as resp:
assert resp.status == 200
return await resp.text()
async def main(loop=loop, url=None):
async with aiohttp.ClientSession(loop=loop) as client:
html = await fetch(client, url)
print(html)
def signal_handler(signal, frame):
loop.stop()
client.close()
sys.exit(0)
signal.signal(signal.SIGINT, signal_handler)
tasks = []
for item in lists:
url = "{url}/{endpoint}/{coin_name}".format(
url='https://coincap.io',
endpoint='page',
coin_name=item.upper()
)
print(url)
tasks.append(
asyncio.ensure_future(main(url=url))
)
loop.run_until_complete(asyncio.gather(*tasks))
【问题讨论】:
标签: python asynchronous python-requests python-asyncio aiohttp