aiohttp响应后为何抛错
用sleep代替请求是没问题的import asyncio,aiohttp
async def test(i):
print("start...")
await asyncio.sleep(2)
print("end...")
return i
sites = [
'https://www.bilibili.com',
'https://fishc.com.cn/'
]
async def main():
tasks =
print(await asyncio.gather(*tasks))
asyncio.run(main())
可以正常运行。如果把test函数改成下面的
async def test(url):
print("start...")
async with aiohttp.ClientSession() as session:
async with session.get(url) as resp:
print("end...")
return resp.status
就会运行大几率报错:
RuntimeError: Event loop is closed
这个是为什么呢 aiohttp官方文档用的异步事件循环还是下面这种形式
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
{:10_253:}
asyncio.run(main())是新的形式,aiohttp应该还没完全兼容把
应该是兼容问题和系统版本python版本有关,官方说后续版本会修复https://github.com/aio-libs/aiohttp/issues/4324
CH10 发表于 2020-9-30 11:53
aiohttp官方文档用的异步事件循环还是下面这种形式
loop = asyncio.get_event_loop()
loop.run_until_com ...
asyncio.run(main())和下面的三连句
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
loop.close()
效果应该是一模一样
{:10_253:}只要我不loop.close() 错误就追不上我吗{:10_289:}
我复现了无数次然后发现
如果请求的是http(http重定向到https的除外)无论什么方式都不会报错
如果请求的是https 或者http重定向到https的才会报错
所以问题应该是出在aiohttp要如何请求https吧 盲目分析加百度说用aiosocksy模块但是看不懂demo{:10_289:}
页:
[1]