Gunicorn (独角兽)是一个高效的Python WSGI Server,通常用它来运行 wsgi application(由我们自己编写遵循WSGI application的编写规范) 或者 wsgi framework(如Django,Paster),地位相当于Java中的Tomcat。
WSGI就是这样的一个协议:它是一个Python程序和用户请求之间的接口。WSGI服务器的作用就是接受并分析用户的请求,调用相应的python对象完成对请求的处理,然后返回相应的结果。
简单来说gunicorn封装了HTTP的底层实现,我们通过gunicorn启动服务,用户请求与服务相应都经过gunicorn传输
步骤:
1.进入目录,创建虚拟环境
cd /home/www/blog
virtualenv venv
2.激活虚拟环境:
source venv/bin/activate
3. 然后根据requirements.txt
文件安装依赖包:
pip3 install -r requirements.txt
4. 安装gunicorn
pip3 install gunicorn
5.编写应用启动脚本
我把启动脚本命名为server.py
"""
服务启动入口
该脚本只用于启动,不涉及任何flask逻辑
"""
from app import app
if __name__ == '__main__':
app.run(debug=True, host='0.0.0.0', port=8000)
这里说明一下,import的app就是创建出来的flask.Flask对象。
6.启动gunicorn
gunicorn server:app
这里的server就是上面的server.py脚本,app就是import的app。
这一步后,就可以在本地通过127.0.0.1:8000访问网站了,目前的绑定IP和端口都是Gunicorn默认的,可以通过启动参数指定。
补充说明:
上面的启动命令是“临时”的,控制台退出后服务也就停止了。为了让服务一直运行,需要将其设为守护进程,加入 - D参数
gunicorn -D server:app
以下为更多配置, 可根据需要添加
gunicorn -D -w 3 -b 0.0.0.0:5000 --error-logfile /var/gunicorn/gunicorn.error.log debug_server:app
进阶
引入Nginx
1.修改Nginx的配置文件
vim /usr/local/nginx/conf/nginx.conf
添加如下配置
server {
listen 80;
server_name xubobo.com;
location / {
proxy_pass http://127.0.0.1:8000;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
- 监听http默认的端口号80
- server_name:个人网站域名
- 把请求代理到本机的8000端口(gunicorn启动服务指定的端口)
剩下proxy_set_header照抄
2. 重新加载nginx的配置
service nginx reload
3. 然后我们就可以通过nginx来访问网站了
通过ip或者域名都可以
gunicorn和nginx关系:
gunicorn 可以单独提供服务,但生产环境一般不这样做。首先静态资源(js,css,img)会占用不少的请求资源,而对于 gunicorn 来讲它本身更应该关注实际业务的请求与处理而不应该把资源浪费在静态资源请求上;此外,单独运行 gunicorn 是没有办法起多个进程多个端口来负载均衡的。
nginx 的作用就是弥补以上问题,首先作为前端服务器它可以处理一切静态文件请求,此时 gunicorn 作为后端服务器,nginx 将会把动态请求转发给后端服务器,因此我们可以起多个 gunicorn 进程,然后让 nginx 作均衡负载转发请求给多个 gunicorn 进程从而提升服务器处理效率与处理能力。最后,nginx 还可以配置很多安全相关、认证相关等很多处理,可以让你的网站更专注业务的编写,把一些转发规则等其它业务无关的事情交给 nginx 做