前言
最近在用django部署网站www.aihunter.cc,经历各种坑后觉得有必要总结一下流程以备日后遗忘。在下阅读众多教程后觉得网上还是缺少介绍Ngnix +Uwsgi + virtualenv+django工作流程的概念文章,结合网上的材料和自己消化本教程将分为概念部分(上篇)以及操作部分(下篇),文中操作内容均为自己实际部署时的流程。另外在下职业非专业程序员若有错误可以在评论中指出,我会必第一时间纠正。
如何部署一个django项目呢?
django从本地环境部署到服务器上需要服务器软件以及用于服务器和应用程序之间通信的
接口(网关)这两部分支持。主流的django部署方式有apache + mod_wsgi 或 ngnix + uWSGI。
Apache 和 Nginx 部署有什么不同呢?
两者之间的差异主要在服务器软件的特点和部署流程上。
Apache的优点在于模块多、bug少。
Nginx的优点在于占用资源少和配置简洁。
其实以上都不是两者之间的主要差别,我是小白角度来看它们的优点的(哪个最适合吊丝服务器)。
Nginx 是什么?它是怎么样处理请求的?
Nginx 是一个HTTP和反向代理服务器,Nginx由基础模块、核心模块、第三方模块这三类构成,Nginx的核心模块有HTTP模块、EVENT模块、MALL模块。
Nginx 处理流程是这样的,当Nginx服务器收到一个请求后就查找Nginx文件夹下的配置文件conf,将请求映射到一个location block,然后被映射的location中配置的各个指令会启动不同的模块去完成对应工作。
WSGI \ uWSGI \ uwsgi 究竟是什么鬼?它们有什么作用呢?
WSGI是接口规范;uWSGI 是服务器;uwsgi是uWSGI的自有协议。定义如下
WSGI
python对web应用和web服务器交互的接口规范。
uWSGI
一个基于WSGI规范的web服务器(当应用需要uWSGI和另外一个服务器连接时,uWSGI身份就会变成中间件,如Ngnix +uWSGI +django,uWSGI就是一个中间件)
uwsgi
uWSGI服务器的自有协议,用于定义传输信息的类型。
uWSGI负责将请求按照指定协议解析,然后把解析的结果设置到environ变量中,接着按照WSG规范回调web应用,uWsgi默认回调application函数,传递eviron和start_response两个参数,最后接受web应用处理返回的结果。
virtualenv是什么?
virtualenv是用来创建隔离的python环境,为应用创建一个独立的安装目录,保证不同的运行条件下各应用的独立性。
四者之间的是怎样进行工作的?
首先,Nginx负责接受外部客户端请求并对其htpp请求进行解包,若请求是静态文件则根据设置好的静态文件路径返回对应内容。若请求是动态内容则将请求交给uWSGI服务器(nginx和uWSGI使用socket通信)。
然后,uWSGI服务器根据wsgi协议解析并回调virtualenv中的django应用。
接着,django则根据请求进行数据库查找和模版渲染等工作(总之就是返回一个响应内容)然后再逆方向返回到Nginx
最后,Nginx将响应交给客户端。
参考
Nginx + uWsgi 部署 Django + Mezzanine 生产服务
Nginx工作原理和优化、漏洞。