uwsgi + nginx 部署python项目(一)
uWSGI
uWSGI是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。
要注意 WSGI / uwsgi / uWSGI 这三个概念的区分。
- WSGI是一种通信协议,Flask,webpy,Django、CherryPy等等都自带WSGI,不过性能都不好。
- uwsgi同WSGI一样是一种通信协议。
- 而uWSGI是实现了uwsgi和WSGI两种协议的Web服务器。
为什么有了uWSGI为什么还需要nginx?因为nginx具备优秀的静态内容处理能力,然后将动态内容转发给uWSGI服务器,这样可以达到很好的客户端响应。
安装
pip install uwsgi
编写uwsgi.ini文件
在项目目录下touch一个ini文件,名称随意,vim进去,复制以下代码
[uwsgi] socket = 0.0.0.0:8000 # 设置0.0.0.0表示可以接收不同服务器的nginx发送过来的请求,127.0.0.1表示只接收同一服务器发送过来的请求, 8000为应用内的监听端口
# http = 0.0.0.0:8000 # http为直接作为web服务器启动 chdir = /knowledge # 指向项目目录 wsgi-file = app.py # 程序启动文件 callable = app # 程序内应用变量名 processes = 2 # 处理器数量 threads = 4 # 线程数
启动应用
uwsgi --ini uwsgi.ini # 启动后直接进控制台
nohup uwsgi --ini uwsgi.ini & # 后台启动uwsgi服务器
kill -9 pid # 关闭服务,直接kill uwsgi的端口
nginx
什么是nginx?
nginx是一款轻量级的Web 服务器 、反向代理服务器及电子邮件(IMAP/POP3)代理服务器。主要有反向代理,负载均衡的功能。
什么是反向代理?
正向代理是服务器经过正向代理服务器把数据给到客户端,反向代理就是多个不同的客户端发出请求到反向代理服务器(nginx),反向代理服务器按照一定规则把请求分发给服务器A,服务器B,服务器C。
正向代理客户端非常明确要访问的服务器地址,服务器只清除请求来自哪个代理服务器,而不清楚来自哪个具体的客户端。反向代理客户端不知道访问的服务器地址是哪个,只能由反向代理服务器去分配请求给某个具体的服务器。
什么是负载均衡?
将服务器接收到的请求按照规则分发的过程。
- weight轮询(默认):接收到的请求按照顺序逐一分配到不同的后端服务器,即使在使用过程中,某一台后端服务器宕机,nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。 这种方式下,可以给不同的后端服务器设置一个权重值(weight),用于调整不同的服务器上请求的分配率;权重数据越大,被分配到请求的几率越大;该权重值,主要是针对实际工作环境中不同的后端服务器硬件配置进行调整的。
- ip_hash: 每个请求按照发起客户端的ip的hash结果进行匹配,这样的算法下一个固定ip地址的客户端总会访问到同一个后端服务器,这也在一定程度上解决了集群部署环境下session共享的问题。
- fair: 智能调整调度算法,动态的根据后端服务器的请求处理到响应的时间进行均衡分配,响应时间短处理效率高的服务器分配到请求的概率高,响应时间长处理效率低的服务器分配到的请求少;结合了前两者的优点的一种调度算法。但是需要注意的是nginx默认不支持fair算法,如果要使用这种调度算法,请安装upstream_fair模块
- url_hash: 按照访问的url的hash结果分配请求,每个请求的url会指向后端固定的某个服务器,可以在nginx作为静态服务器的情况下提高缓存效率。同样要注意nginx默认不支持这种调度算法,要使用的话需要安装nginx的hash软件包
安装nginx
apt-get install nginx
nginx常用命令
service nginx start # 启动
service nginx stop # 停止
service nginx reload # 重启
service nginx status # 查看nginx状态
nginx -v # 查看版本
配置文件
cd 到安装目录,一般是/etc/nginx,里面有个nginx.conf文件
vim 进去,匹配顺序是先ip > 端口 > location
http { server { listen 81; # nginx的监听端口,浏览器访问的端口,等同于0.0.0.0:81, 表示可以接收任何IP发的请求 server_name 0.0.0.0; # 可以直接写域名如:www.flasktest.com,但是需要在hosts文件设置IP和域名的对应关系 charset UTF-8; access_log /etc/nginx/FlaskTest_access.log; error_log /etc/nginx/FlaskTest_error.log; client_max_body_size 75M; # 请求文件的最大大小 location / { include uwsgi_params; uwsgi_pass 127.0.0.1:82; # 上面的匹配成功后,会请求这个地址 uwsgi_read_timeout 2; } } }