flask是如何处理多个访问请求的?
假设服务器跑着这样一段简单的flask代码:
app = Flask() @app.route('/') def index(): return render_temple('index.html')
这时候服务器来了两个访问请求,这两个请求都被路由到@app.route('/').
请问flask是如何同时处理这两个请求的 ? 如果我的代码没有实现任何并发功能,flask会自动帮我处理并发请求吗 ? 如果有Nginx这类HTTP服务器,情况又是怎样?
希望各位能指导下,给个解答或者指明下学习方向都行 !
解决方法
这段程序只是一个APP服务的一个路由。你的APP服务又被用WSGI接入到HTTP服务器,就是你说的Nginx。这个问题跟Nginx无关,因为这里它只是一个通道。跟Flask也无关,因为它只是负责根据Request产生Response。有关的就是WSGI server。通常来讲WSGI server是通过进程(pre-fork)来并发的。这样并发就取决与进程数。如果WSGI server用了gevent, eventlet等 green thread技术,就可以支持更多并发。
如果使用下面的启动方式,你的代码没有实现任何并发功能,flask 不会自动帮你处理并发请求;
python app.py
可以通过加一个 time.sleep 做测试, 比如下面代码:
import time app = Flask() @app.route('/') def index(): time.sleep(5) # 单位秒 return render_temple('index.html')
多进程
多进程的话,可以使用 gunicorn 来启动。 -w 后面跟的参数就是代表进程数量,同样,可以通过 time.sleep 测试。
gunicorn app -w 2 -b :8000
异步
可以使用 gevent 来处理。
Python 3.5 提供了新的异步 API(介绍)。