Flask

gevent启动多进程WSGI

2017-04-25  本文已影响0人  那脸憔悴

使用gevent启动flask或是bottle web服务时默认都是单进程,并发性能有限。
可以使用gunicorn配合gevent来启动多进程。
现在使用multiprocessing配合gevent来启动多进程

from gevent import monkey
monkey.patch_all()

from gevent.pywsgi import WSGIServer
from multiprocessing import cpu_count, Process
from bottle import Bottle

app = Bottle()


@app.get("/")
def index():
    return {"hello": "world"}

server = WSGIServer(('', 8000), app, log=None)
server.start()

def serve_forever():
    server.start_accepting()
    server._stop_event.wait()

if __name__ == "__main__":
    # server.serve_forever()
    # 启动的进程数为cpu个数
    for i in range(cpu_count()):
        p = Process(target=serve_forever)
        p.start()

这种是多进程模式
单进程模式:
1.屏蔽 server.start()
2.打开 server.serve_forever()
3.屏蔽 最后三行
使用多进程启动的服务要比单进程的并发高出很多倍
多进程模式是比较理想的

上一篇 下一篇

猜你喜欢

热点阅读