- [*] 本文出处:http://b1u3buf4.xyz/
- [*] 本文作者:B1u3Buf4
- [*] 本文授权:禁止转载
从自己的博客移动过来。
gunicorn是一个python Wsgi的WEB服务框架,只支持在Unix系统上运行,来源于Ruby的unicorn项目。虽然可以独自运行,但功能比较单一,通常是部署在Apache,Nginx之后。Gunicorn使用prefork master-worker模型,能够与各种wsgi web框架协作。
gunicorn安装非常简单,使用命令pip install guncorn
即可。一般使用它,主要是为使用其异步的worker模型,还需要安装对应的异步模块。
$ pip install greenlet #使用异步必须安装
$ pip install eventlet #使用eventlet workers
$ pip install gevent #使用gevent workers
后面的内容使用Flask进行举例,代码选自Flask首页给出的测试代码,保存为test.py:
from flask import Flask
app = Flask(__name__)
@app.route("/")
def hello():
return "Hello World!"
通常使用的参数:
-c CONFIG, --config=CONFIG
设定配置文件。
-b BIND, --bind=BIND
设定服务需要绑定的端口。建议使用HOST:PORT。
-w WORKERS, --workers=WORKERS
设置工作进程数。建议服务器每一个核心可以设置2-4个。
-k MODULE
选定异步工作方式使用的模块。
在shell中输入你的启动配置,比如gunicorn -w 3 -b 127.0.0.1:8080 test:app
,然后运行正常就可以启动服务器。
linux通常会禁止绑定使用1024以下的端口,除非在root用户权限。很多人在使用gunicorn时试图将其绑定到80或者443端口,发现无效。如果想绑定到这些端口,常见的有如下的几种方法:
1、使用Nginx代理转发。
2、sudo启动gunicorn。
3、安装额外的程序。
如果使用方法2,要确保在sudo状态下使用pip安装的gunicorn,否则可能出奇怪问题。
使用pstree -ap|grep gunicorn
列出关于gunicorn的所有进程。输出内容是一个树形结构,最小的一级是worker进程,他们的上一级是gunicorn进程。使用kill -HUP [gunicorn的进程ID]
杀掉进程。如果该进程还存在上一级进程,使用kill -9 [进程ID]
将其彻底关闭。之后再重新执行pstree -ap|grep gunicorn
查看一下。