美文网首页
flask多并发

flask多并发

作者: xieyan0811 | 来源:发表于2023-03-24 20:26 被阅读0次

    多线程

    flask默认使用多进程处理请求,因此,是支持并发的。比如两个调用a.html和b.html,

    • 请求a.html未运行完成,在浏览访问b.html不会阻塞。
    • 开两个不同浏览器,分别请求请求运行时间较长的a.html也不阻塞。只要不用一个浏览去调,它都是不阻塞的;如果开一个浏览器在不同tab页请求同一阻塞页面,则会阻塞,这是浏览器引起的。

    WSGI协议

    WSGI是Web Server Gateway Interface的缩写,它是Python应用程序或者框架(如Flask)和web服务器之间的一种接口。flask默认使用werkzeug库实现WSGI协议。
    只要实现了WSGI协议的任何web server都可以作为flask app的服务器,比如uWSGI, Gunicorn,mod_wsgi都可以替换Werkzeug作为 web server。

    flask自带的多进程

    • 在app.run()时加入参数:threaded=False, processes=5, debug=False时,可使用5个进程。
    • 进入flash的app.run()函数内部,可以看到真正使用werkzeug库来实现后台服务。
    • flask自带的多进程有一个问题,每次请求时进程开启,该请求运行结束进程关闭,因此无法在每个进程中保留现场,每次都做初始化,也会浪费很多时间。

    gunicorn

    • 如果想在flash一开始就启多个进程,可使用gunicorn
    • 做如下的test.py
    from flask import Flask
    app = Flask(__name__)
    
    @app.route("/")
    def hello():
        return "Hello World!"
    

    注意:使用gunicorn后,无需在程序中运行app.run()。

    • 运行命令
    gunicorn -w 3 -b 0.0.0.0:8080 test:app
    

    这里设成开启3个进程,0.0.0.0使得在docker内部启动的服务可在宿主机上被访问,test是py文件名,app是其中的flask服务名。此时,使用ps命令即可看到一开始就启动了多个进程。

    参考

    Flask: flask框架是如何实现非阻塞并发的

    相关文章

      网友评论

          本文标题:flask多并发

          本文链接:https://www.haomeiwen.com/subject/jcrgrdtx.html