使用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.屏蔽 最后三行
使用多进程启动的服务要比单进程的并发高出很多倍
多进程模式是比较理想的