多线程
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命令即可看到一开始就启动了多个进程。