python 异步Web框架sanic

我们继续学习Python异步编程,这里将介绍异步Web框架sanic,为什么不是tornado?从框架的易用性来说,Flask要远远比tornado简单,可惜flask不支持异步,而sanic就是类似Flask语法的异步框架。

github:GitHub - sanic-org/sanic: Accelerate your web app development | Build fast. Run fast.

不过sanic对环境有要求:

macOS/linux

python 3.6+

不过,我在macOS上安装 sanic 还是踩了坑。依赖库ujson一直安装失败。最后不得不卸载官方python,安装 miniconda(第三方Python安装包,集成了一些额外的工具)。

安装 sanic

复制代码
> pip3 install sanic

sanic 开发第一个例子

编写官方的第一个例子hello.py

复制代码
from sanic import Sanic
from sanic.response import json
from sanic.exceptions import NotFound
 
 
app = Sanic(name="pyapp")
 
@app.route('/')
async def test(request):
    return json({'hello': 'world'})
 
 
if __name__ == '__main__':
    app.error_handler.add(
        NotFound,
        lambda r, e: sanic.response.empty(status=404)
    )
    app.run(host='0.0.0.0', port=8000)

运行上面的程序:

复制代码
> python3 hello.py
 
[2020-04-21 23:12:02 +0800] [18487] [INFO] Goin Fast @ http://0.0.0.0:8000
[2020-04-21 23:12:02 +0800] [18487] [INFO] Starting worker [18487]

通过浏览器访问:http://localhost:8000/

请求堵塞

针对上面的例子,假设test() 视图函数的处理需要5秒钟,那么请求就堵塞了。

复制代码
......
 
from time import sleep
 
app = Sanic(name="pyapp")
 
@app.route('/')
async def test(request):
    sleep(5)
    return json({'hello': 'world'})
 
......

重启服务,通过浏览器发送请求,我们发现请求耗时5秒,这显然对用户就不能忍受的。

异步非堵塞

所以,我们要实现异步调用,修改后的完整代码如下:

复制代码
import asyncio
from sanic import Sanic
from sanic.response import json
from sanic.exceptions import NotFound
from time import sleep, ctime
 
app = Sanic(name="pyapp")
 
async def task_sleep():
    print('sleep before', ctime())
    await asyncio.sleep(5)
    print('sleep after', ctime())
 
 
@app.route('/')
async def test(request):
    myLoop = request.app.loop
    myLoop.create_task(task_sleep())
    return json({'hello': 'world'})
 
 
if __name__ == '__main__':
    app.error_handler.add(
        NotFound,
        lambda r, e: sanic.response.empty(status=404)
    )
    app.run(host='0.0.0.0', port=8000)

关于python异步的使用参考上一篇文章,重新启动服务。这次前端就不在堵塞了。

如果看 sanic 的运行日志:

2020-04-21 23:43:14 +0800\] - (sanic.access)\[INFO\]\[127.0.0.1:57521\]: GET http://localhost:8000/ 200 17 sleep before Tue Apr 21 23:43:14 2020 sleep after Tue Apr 21 23:43:19 2020 他仍然在执行,但不会堵塞test()视图函数的响应。 他仍然在执行,但不会堵塞`test()`视图函数的响应。 > 思考:假如我的需求是:请求之后先告诉我已经处理了,然后默默的去处理,什么时候处理来再主动把处理的结果告诉。那么这就需要用到 websocket了。

相关推荐
写不来代码的草莓熊1 分钟前
vue前端面试题——记录一次面试当中遇到的题(9)
前端·javascript·vue.js
哦你看看11 分钟前
学习Python 03
开发语言·windows·python
后端小张14 分钟前
[AI 学习日记] 深入解析MCP —— 从基础配置到高级应用指南
人工智能·python·ai·开源协议·mcp·智能化转型·通用协议
天青色等烟雨..16 分钟前
AI+Python驱动的无人机生态三维建模与碳储/生物量/LULC估算全流程实战技术
人工智能·python·无人机
JinSo21 分钟前
pnpm monorepo 联调:告别 --global 参数
前端·github·代码规范
新子y21 分钟前
【小白笔记】岛屿的周长(Island Perimeter)
笔记·python
程序员码歌28 分钟前
豆包Seedream4.0深度体验:p图美化与文生图创作
android·前端·后端
小龙报31 分钟前
《彻底理解C语言指针全攻略(6)-- qsort、sizeof和strlen》
c语言·开发语言·职场和发展·创业创新·学习方法·业界资讯·visual studio
urhero32 分钟前
工作事项管理小工具——HTML版
前端·html·实用工具·工作事项跟踪·任务跟踪小工具·本地小程序
二十雨辰33 分钟前
eduAi-智能体创意平台
前端·vue.js