flask+aiohttp实现异步协程来减少请求耗时

文章展示了如何创建一个简单的Flask应用,该应用有四个路由每个都会延迟1秒返回响应。然后通过aiohttp库,利用协程和异步IO进行并发请求,以减少总耗时。最后,文章计算并打印出总耗时,强调了异步请求在处理多个HTTP请求时的效率优势。
摘要由CSDN通过智能技术生成

首先搭建一个简易的flask页面,如下:

from flask import Flask
import time
from flask import Flask
import time

app = Flask(__name__)


@app.route('/111')
def index_1():
    time.sleep(1)
    return 'Hello 111'


@app.route('/222')
def index_2():
    time.sleep(1)
    return 'Hello 222'


@app.route('/333')
def index_3():
    time.sleep(1)
    return 'Hello 333'


@app.route('/444')
def index_4():
    time.sleep(1)
    return 'Hello 444'


if __name__ == '__main__':
    app.run(threaded=True)

接下来就是aiohttp实现异步请求的代码页面:

import time
import aiohttp
import asyncio

# 计时
start = time.time()


# 定义一个协程对象,async表示定义一个协程对象,with表示安全打开和自动关闭模式
async def http(url):
    async with aiohttp.ClientSession() as session:
        # await表示阻塞挂起
        async with await session.get(url) as respond:
            print(await respond.text())


urls = [
    'http://127.0.0.1:5000/111',
    'http://127.0.0.1:5000/222',
    'http://127.0.0.1:5000/333',
    'http://127.0.0.1:5000/444'
]
# 准备一个tasks数组
tasks = []
# 对协程对象进行封装为task
for url in urls:
    cop = http(url)
    task = asyncio.ensure_future(cop)
    tasks.append(task)
# 把task注册到时间循环中
loop = asyncio.get_event_loop()
loop.run_until_complete(asyncio.wait(tasks))
end = time.time()
print('总耗时:', end-start)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Double Handsome

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值