之前写了几篇关于各种服务器部署Django的文章(链接在文末),很多朋友看了,并部署了之后,还是对部署原理一知半解。这篇文章和大家一起了解一下Django部署原理以及各种服务器组件之间的工作流程。方便大家对部署了解得更透彻。
1、各组件工作流程:
Django本身只是一个基于Python语言写的一个开源WEb框架,不具备服务器网关功能,不可以直接访问得到。如果我们想通过外网访问Django项目。那么我们做为客户端,首先向服务端发出请求,这时服务端有一个对外服务的组件或接口(如Nginx、Apche等)接收客户端发来的HTTP请求,并对这个请求进行解包分析,如果是静态文件请求就根据nginx配置的静态文件目录,返回请求的资源,如果是动态的请求,nginx就通过配置文件,将请求传递给uWSGI;然后uWSGI 将接收到的包进行处理,并转发给wsgi,wsgi根据请求调用django工程的某个文件或函数,处理完后django将返回值交给wsgi,最后wsgi将返回值进行打包,转发给uWSGI,uWSGI接收后转发给nginx,nginx最终将返回值返回给客户端(如浏览器)。
各个组件之间的工作流程
在上边我们有提及了Nginx、uWsgi、wsgi,下边我对这几个组件进行简单介绍一下。
wsgi:
django项目携带的一个wsgi接口文件如果项目名叫myblog的话,此文件就位于[myblog/myblog/wsgi.py]目录中一种实现python解析的通用接口标准/协议,是一种通用的接口标准或者接口协议,实现了python web程序与服务器之间交互的通用性。 利用它,django等的python web开发框架,就可以轻松地部署在不同的web server上了。
uWSGI:
一个基于自有的uwsgi协议、wsgi协议和http服务协议的web网关。它一种python web server或称为Server/Gateway。uWSGI是实现了uwsgi和WSGI两种协议的Web服务器,负责响应python 的web请求。
Nginx:
一个常用高性能代理服务器。它自己没有解析动态语言的功能。所以分给其它模块来做。在Django部署中,uWSGI实现了wsgi协议、uwsgi协议、http等协议,所以Nginx中的模块HttpUwsgiModule的作用是与uWSGI服务器进行交换。
所以我们部署的时候才需要使用 Nginx和uWSGI组合部署django。其实nginx并不是必须的,uwsgi完全可以完成整个的和浏览器交互的流程;但nginx在其它安全性或其他的限制,可以达到保护程序的作用,nginx也可以代理多台uWSGI完成uWSGI的负载均衡;且对静态文件的处理能力用nginx来处理更加高效,所以才使用Nginx与uWSGI一起组合使用。
二、安装与部署
首先,确保服务器安装好了Python环境,并完成了pip的安装。如果没有请安装。因为大部分Linux自带的Python版本与Django所需要的版本不一致,或者想要安装部署多个版本的Django或Python,所以一般推荐使用virtualenv,通过虚拟环境来部署。
其次,确保安装好nginx,并能正常运行。
然后,确保安装好了Django及所需的依赖框架包。测试方法:python manage.py runserver 0.0.0.0:8000
最后,安装uWSGI。
上面都没问题了,就配置nginx和uwsgi。假设我们的django项目名为mysite,位于/www/wwwroot/mysite目录下。
uWsig配置
在项目文件里创建 uwsgi.ini 文件,编辑文件 ,配置uwsgi:
#添加配置选择 [uwsgi] #配置和nginx连接的socket连接 socket=127.0.0.1:8997 #配置项目路径,项目的所在目录 chdir=/www/wwwroot/mysite/ #配置wsgi接口模块文件路径,也就是wsgi.py这个文件所在的目录名 wsgi-file=mysite/wsgi.py #配置启动的进程数 processes=4 #配置每个进程的线程数 threads=2 #配置启动管理主进程 master=True #配置存放主进程的进程号文件 pidfile=uwsgi.pid #配置dump日志记录 daemonize=uwsgi.log
通过下面的命令启动运行uwsgi
uwsgi --ini uwsgi.ini
显示 [uWSGI] getting INI configuration from uwsgi.ini 表明uwsgi运行成功
可能通过ps -ef|grep uwsgi 查看确认是否uwsgi启动.
uwsg.ini配置文件其它相关命令:
#停止运行uwsgi,通过包含主进程编号的文件设置停止项目 uwsgi --stop uwsgi.pid #重启uwsgi uwsgi --reload uwsgi.pid
nginx配置
假设nginx安装好的路径为/usr/local/nginx,则在/usr/local/nginx/conf/中先备份一下nginx.conf文件,以防意外。
cp nginx.conf nginx.conf.bak
然后打开nginx.conf,把原来的内容删除,直接加入以下内容:
events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; server { listen 80; server_name www.django.cn; #改为自己的域名,没域名修改为127.0.0.1:80 charset utf-8; location / { include uwsgi_params; uwsgi_pass 127.0.0.1:8997; #端口要和uwsgi里配置的一样 uwsgi_param UWSGI_SCRIPT mysite.wsgi; #wsgi.py所在的目录名+.wsgi uwsgi_param UWSGI_CHDIR /www/wwwroot/mysite/; #项目路径 } location /static/ { alias /www/wwwroot/mysite/static/; #静态资源路径 } } }
进入/usr/local/nginx/sbin/目录
执行
./nginx -t
命令先检查配置文件是否有错,没有错就执行以下命令:
./nginx
这样不出意外就能部署成功。关于部署原理就介绍到这里,如果需要更详细的部署文章,可以查看下面的链接。
文章参考:https://blog.csdn.net/c465869935/article/details/53242126