当我们执行下面的hello.py时,使用的flask自带的服务器,完成了web服务的启动。在生产环境中,flask自带的服务器,无法满足性能要求,我们这里采用Gunicorn做wsgi容器,来部署flask程序。Gunicorn(绿色独角兽)是一个Python WSGI的HTTP服务器。从Ruby的独角兽(Unicorn )项目移植。该Gunicorn服务器与各种Web框架兼容,实现非常简单,轻量级的资源消耗。Gunicorn直接用命令启动,不需要编写配置文件,相对uWSGI要容易很多。
区分几个概念:
WSGI:全称是Web Server Gateway Interface(web服务器网关接口),它是一种规范,它是web服务器和web应用程序之间的接口。它的作用就像是桥梁,连接在web服务器和web应用框架之间。
uwsgi:是一种传输协议,用于定义传输信息的类型。
uWSGI:是实现了uwsgi协议WSGI的web服务器。
我们的部署方式: nginx + gunicorn + flask
# hello.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello():
return 'hello world
'
if __name__ == '__main__':
app.run(debug=True)
使用Gunicorn:
web开发中,部署方式大致类似。简单来说,前端代理使用Nginx主要是为了实现分流、转发、负载均衡,以及分担服务器的压力。Nginx部署简单,内存消耗少,成本低。Nginx既可以做正向代理,也可以做反向代理。
正向代理:请求经过代理服务器从局域网发出,然后到达互联网上的服务器。
特点:服务端并不知道真正的客户端是谁。
反向代理:请求从互联网发出,先进入代理服务器,再转发给局域网内的服务器。
特点:客户端并不知道真正的服务端是谁。
区别:正向代理的对象是客户端。反向代理的对象是服务端。
安装gunicorn
pip install gunicorn
查看命令行选项: 安装gunicorn成功后,通过命令行的方式可以查看gunicorn的使用信息。
$ gunicorn -h
直接运行:
# 直接运行,默认启动的127.0.0.1::8000
$ gunicorn 运行文件名称:Flask程序实例名
指定进程和端口号: -w: 表示进程(worker)。 -b:表示绑定ip地址和端口号(bind)。--access-logfile:表示指定log文件的路径
$ gunicorn -w 4 -b 127.0.0.1:5000 --access-logfile log文件路径 运行文件名称:Flask程序实例名
# 例:gunicorn -w 4 -b 0.0.0.0:5000 --access-logfile ./logs/log health:app
作为守护进程后台运行:
$ gunicorn -w 4 -b 127.0.0.1:5000 -D --access-logfile log文件路径 运行文件名称:Flask程序实例名
# 例:gunicorn -w 4 -b 0.0.0.0:5000 -D --access-logfile ./logs/log health:app
安装Nginx
$ sudo apt-get install nginx
阿里云服务器默认安装到 /user/sbin/ 目录,进入目录,启动 ngnix:
# 启动
sudo nginx
# 查看
ps aux | grep nginx
# 停止
sudo nginx -s stop
# 重启
sudo nginx -s reload
Ubuntu 上配置 Nginx 也是很简单,不要去改动默认的 nginx.conf 只需要将/etc/nginx/sites-available/default文件替换掉就可以了。
新建一个 default 文件,添加以下内容:
upstream flask {
server 127.0.0.1:5000; # Gunicorn 配置的ip和端口
}
server {
listen 80; # 监听80端口
server_name localhost; # 本机
location / {
# 请求转发到gunicorn服务器
proxy_pass http://flask;
# 设置请求头,并将头信息传递给服务器端
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
修改完成后重启nginx即可。
补充:
Ubuntu 上配置 Nginx 另一种方法,cd 到 /etc/nginx/conf.d 文件夹,新建 xxx.conf 文件(xxx 可以是项目名,只要是 .conf 文件即可),写入以下内容:
upstream flask {
server 127.0.0.1:5000; # Gunicorn 配置的ip和端口
}
server {
listen 80; # 监听80端口
server_name localhost; # 本机
location / {
# 请求转发到gunicorn服务器
proxy_pass http://flask;
# 设置请求头,并将头信息传递给服务器端
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}
需要监听 https 请求时,写入以下内容:
upstream health {
server 127.0.0.1:5000; # Gunicorn 配置的 ip 和端口
}
server {
listen 9000 ssl; # 443 端口被占用,这里监听 9000 端口
server_name health; # 这里填入 上面的 upstream 对应的 health 也可以(localhost 也可以)
ssl_certificate cert/2979212_www.zolarobot.com.pem; # 证书公钥,这里在nginx.conf所在文件夹下面的cert文件夹里面
ssl_certificate_key cert/2979212_www.zolarobot.com.key; # 证书私钥
location / {
proxy_pass http://health;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
}
}