话接上文,https://www.cnblogs.com/CooperXia-847550730/p/11526734.html文里写了一个随机图片API只用了flask部署,非常不稳定,
几个小时就dead了,所以打算部署在nginx服务器上,
首先介绍一下:
nginx 是一个web服务器,用来接收请求,建立连接,转发到后台等
uwsgi其实也是一个web服务器,但是还是没有nginx稳定,处理迸发也不如nginx,这里用uwsgi只是为了让nginx实现反向代理,flask是没办法直接被nginx反向代理的。
flask就是一个web框架,实现网站功能
ok,接下来开始部署,首先安装nginx和uwsgi
yum install nginx
pip3 install uwsgi
就可以了
uwsgi的食用方法:
uwsgi --socket 0.0.0.0:5000 --protocol=http -p 3 -w run:app
这样可以直接启动,
--socket 0.0.0.0:5000
:指定暴露端口号为5000。
--protocol=http
:说明使用 http 协议,即端口5000可以直接使用HTTP请求进行访问。
-p 3
表示启动的服务占用3个进程。
-w run:app
:-w 指明了要启动的模块,run 就是项目启动文件 run.py 去掉扩展名,app 是 run.py 文件中的变量 app,即 Flask 实例。
然后介绍配置文件启动的方法:
在项目目录下新建uwsgi.ini文件,
内容:
[uwsgi]
module = sprocess:app
master = true
processes = 3
chdir = ./
socket = ./project.sock
socket = 127.0.0.1:4000
logto = ./project.log
chmod-socket = 660
vacuum = true
下次启动直接:
nohup uwsgi --ini uwsgi.ini > uwsgi.txt 2>&1 &
(nohup是后台启动命令,可以直接yum安装)
接下来配置nginx服务器,
vim /etc/nginx/nginx.conf,
内容:
worker_processes 4;
events { worker_connections 1024; }
http {
include mime.types;
default_type application/octet-stream;
server{
listen 80;
listen 443 ssl;
ssl_certificate /root/nginxproject/server.crt;
ssl_certificate_key /root/nginxproject/server.key;
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:4000;
}
}
}
其中涉及的crt和key证书 需要用openssl生成,上篇文章已经说了,
如果不需要https去掉这三行就行
listen 443 ssl;
ssl_certificate /root/nginxproject/server.crt;
ssl_certificate_key /root/nginxproject/server.key;
现在就可以访问了!但是博主犯了一个错误,而且很多次,就是每次都忘记去aliyun里打开相应的端口!!!!!!
我死了! 花了一个多小时,以为是证书或者配置的问题,被自己蠢哭