flask是如何处理多个访问请求的?

发布于 2022-09-02 09:51:30 字数 319 浏览 10 评论 0

假设服务器跑着这样一段简单的flask代码:

app = Flask()

@app.route('/')
def index():
    return render_temple('index.html')
    

这时候服务器来了两个访问请求,这两个请求都被路由到@app.route('/').
请问flask是如何同时处理这两个请求的 ? 如果我的代码没有实现任何并发功能,flask会自动帮我处理并发请求吗 ? 如果有Nginx这类HTTP服务器,情况又是怎样?
希望各位能指导下,给个解答或者指明下学习方向都行 ! 万分感谢 !

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

带上头具痛哭 2022-09-09 09:51:30

这段程序只是一个APP服务的一个路由。你的APP服务又被用WSGI接入到HTTP服务器,就是你说的nginx。这个问题跟nginx无关,因为这里它只是一个通道。跟Flask也无关,因为它只是负责根据Request产生Response。有关的就是WSGI server。通常来讲WSGI server是通过进程(pre-fork)来并发的。这样并发就取决与进程数。如果WSGI server用了gevent, eventlet等 green thread技术,就可以支持更多并发。

棒棒糖 2022-09-09 09:51:30

解答你的问题

如果使用下面的启动方式,你的代码没有实现任何并发功能,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

异步

  1. 可以使用 gevent 来处理。

  2. Python 3.5 提供了新的异步 API(介绍)。

2022-09-09 09:51:30

如果是单个worker 是不会同时处理的 只会阻塞住(可能用词不当),用nginx 或者supervisor 是因为可以设置多个worker 同时处理请求, 我是这么理解的

青春有你 2022-09-09 09:51:30

要看你是怎么部署这个程序的,如果是采用Flask默认的Debug Server,那就是单线程的,两个请求会被“串行”地处理,即 @liuxiaoxiaochen 说的第二个请求会被“阻塞”,直到第一个请求执行完才会执行。

如果以多线程方式部署的话,两个请求就能被同时处理的。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文