gunicorn(with gevent)并未解决Flask阻塞问题,求指导..
Flask#server.py:
from flask import Flask
import time
app = Flask(__name__)
@app.route("/")
def index():
time.sleep(10)
return "Hello World"
if __name__=='__main__':
app.run()
gunicorn配置#gun.py:
import os
bind='127.0.0.1:5000'
workers=4
backlog=2048
worker_class="gevent" #sync, gevent,meinheld
debug=True
proc_name='/tmp/gunicorn.pid'
pidfile='/tmp/gunicorndebug.log'
loglevel='debug'
测试脚本#test.py:
import time
import requests
s=time.time()
print requests.get("http://127.0.0.1:5000").text
print time.time()-s
然后启动服务:
gunicorn -c gun.py server:app
同时我开启新的两个shell进行测试,几乎同时执行python test.py
测试结果为:
一个为:
Hello World
19.0649909973
另一个为:
Hello World
19.0649909973
本来Flask就是阻塞的,以为加上gunicorn就ok了,但是显然Flask被阻塞了,请问该如何解决呢?之前用tornado加上@asynchronous
就可以解决阻塞问题...
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
不要用
time.sleep
要用gevent.sleep
,两者的机制不一样的,Tornado使用的是自己的IOLoop,gevent则使用libev(老版本使用libevent)。因此,只有gevent自己的sleep才能通知libev当前协程已被阻塞。gevent的monkey patch也是把各个库里面相关的部分全部改成用libev的才能让gevent起作用。你的问题是 gun.py没有gevent.monkey.patch_all(),所以路由中调用time.sleep(10),没有被替换成gevent.sleep(10)