ubuntu Django + Uwsgi + Nginx 的生产环境部署

一、概述

使用runserver可以使我们的django项目很便捷的在本地运行起来,但这只能在局域网内访问,如果在生产环境部署django,就要多考虑一些问题了。比如静态文件处理,安全,效率等等,本篇文章总结归纳了一下基于uwsgi+Nginx下django项目生产环境的部署

uWSGI是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。

要注意 WSGI / uwsgi / uWSGI 这三个概念的区分。

  • WSGI是一种通信协议。
  • uwsgi是一种线路协议而不是通信协议,在此常用于在uWSGI服务器与其他网络服务器的数据通信。
  • 而uWSGI是实现了uwsgi和WSGI两种协议的Web服务器。

uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型(type of information),每一个uwsgi packet前4byte为传输信息类型描述,它与WSGI相比是两样东西。

准备条件

默认ubuntu已经有了python3,但是pip没有安装。

apt-get install -y python3-pip

安装虚拟环境

pip3 install virtualenv

创建虚拟环境

sudo mkdir /virtualenvs  cd /virtualenvs  sudo /usr/local/bin/virtualenv -p /usr/bin/python3 --no-site-packages venv

安装django

/virtualenvs/venv/bin/pip3 install django

二、运行django项目

创建django项目

root@ubuntu:~# mkdir /www  root@ubuntu:~# cd /www/  root@ubuntu:/www# /virtualenvs/venv/bin/django-admin startproject mysite1  root@ubuntu:/www# cd mysite1/  root@ubuntu:/www/mysite1# /virtualenvs/venv/bin/python manage.py startapp blog  root@ubuntu:/www/mysite1# mkdir static

编辑配置文件

root@ubuntu:/www/mysite1# vim mysite1/settings.py

允许监听所有IP,注意:'*'必须用引号包起来

ALLOWED_HOSTS = ['*']

原生启动方式

/virtualenvs/venv/bin/python manage.py runserver 0.0.0.0:8000

访问页面

http://192.168.10.104:8000/

效果如下:

三、基于uwsgi+django的实现

安装uwsgi

/virtualenvs/venv/bin/pip3 install uwsgi

使用命令启动uwsgi

先关闭上面启动的Django项目,使用Ctrl+c,就可以取消。

第一步:进入django项目

cd /www/mysite1/

第二步:命令测试启动

/virtualenvs/venv/bin/uwsgi --http 0.0.0.0:8000 --file mysite1/wsgi.py --static-map=/static=static

参数说明:

–http 这个就和runserver一样指定IP 端口

–file 这个文件就里有一个反射,如果你在调用他的时候没有指定Web Server就使用默认的

    注意:mysite1是一个相对路径。–file它的绝对路径是/www/mysite1/mysite1/wsgi.py

–static 做一个映射,指定静态文件。

此时,访问http://192.168.10.104:8000/

如果访问正常,表示项目启动成功

uwsgi配置文件

使用Ctrl+c,取消uwsgi启动。

第一步:在django项目同级目录创建uwsgi目录,用于存放相关文件

cd /www/mysite1mkdir uwsgi

项目结构如下:

mysite1/  ├── blog  │   ├── admin.py  │   ├── apps.py  │   ├── __init__.py  │   ├── migrations  │   │   └── __init__.py  │   ├── models.py  │   ├── tests.py  │   └── views.py  ├── db.sqlite3  ├── manage.py  ├── mysite1  │   ├── __init__.py  │   ├── settings.py  │   ├── urls.py  │   └── wsgi.py  ├── uwsgi  └── static

第二步:进入script目录,创建一个uwsgi.ini文件

cd /www/mysite1/uwsgi  vim uwsgi.ini

编辑uwsgi.ini文件内容如下:

[uwsgi]    # Django-related settings  # the base directory (full path)  chdir           = /www/mysite1  # Django's wsgi file  module          = mysite1.wsgi  # the virtualenv (full path)  home            = /virtualenvs/venv  # process-related settings  # master  master          = true  # maximum number of worker processes  processes       = 1  # pid file  pidfile         = /www/mysite1/uwsgi/uwsgi.pid  # The address and port of the monitor  http            = :8000  # clear environment on exit  vacuum          = true  #The process runs in the background and types the log to the specified log file  daemonize       = /www/mysite1/uwsgi/uwsgi.log

注意几个很重要的参数

chdir 项目目录,写绝对路径

module Django的 wsgi 文件,表示mysite1/wsgi.py

home 虚拟环境目录,写绝对路径

daemonize 进程在后台运行,并将日志打到指定的日志文件

启动django项目

root@ubuntu:~# cd /www/mysite1/  root@ubuntu:/www/mysite1# /virtualenvs/venv/bin/uwsgi --ini uwsgi/uwsgi.ini   [uWSGI] getting INI configuration from uwsgi/uwsgi.ini

查看文件

root@ubuntu:/www/mysite1# ll uwsgi/  总用量 20  drwxr-xr-x 2 root root 4096 8月  10 11:47 ./  drwxr-xr-x 6 root root 4096 8月  10 11:27 ../  -rw-r--r-- 1 root root  717 8月  10 11:41 uwsgi.ini  -rw-r----- 1 root root 2021 8月  10 11:47 uwsgi.log  -rw-rw-rw- 1 root root    6 8月  10 11:47 uwsgi.pid

刷新页面,查看访问是否正常。

uwsgi 常用的启动命令

uwsgi --ini uwsgi.ini # 启动  uwsgi --reload uwsgi.pid # 重启  uwsgi --stop uwsgi.pid # 关闭

四、Nginx代理uwsgi

安装nginx

apt-get install -y nginx

编辑配置文件

cd /etc/nginx/sites-enabled  vim mysite1.conf

内容如下:

server {      listen 8000;      server_name localhost;        # 指定项目路径uwsgi      location / {          include uwsgi_params; # 导入一个Nginx模块他是用来和uWSGI进行通讯的          uwsgi_connect_timeout 30; # 设置连接uWSGI超时时间          uwsgi_pass unix:/www/mysite1/uwsgi/mysite1.sock; # 指定uwsgi的sock文件所有动态请求就会直接丢给他      }        # 指定静态文件路径      location /static/ {          alias /www/mysite1/static/;      }    }

更改uwsgi配置

改为socket方式

cd /www/mysite1/uwsgi  vim uwsgi.ini

内容如下:

[uwsgi]    # Django-related settings  # the base directory (full path)  chdir           = /www/mysite1  # Django's wsgi file  module          = mysite1.wsgi  # the virtualenv (full path)  home            = /virtualenvs/venv  # process-related settings  # master  master          = true  # maximum number of worker processes  processes       = 1  # pid file  pidfile         = /www/mysite1/uwsgi/uwsgi.pid  # socket file path (full path)  socket          = /www/mysite1/uwsgi/mysite1.sock  # clear environment on exit  vacuum          = true  #The process runs in the background and types the log to the specified log file  daemonize       = /www/mysite1/uwsgi/uwsgi.log

重新加载uwsgi

/virtualenvs/venv/bin/uwsgi --reload uwsgi.pid

加载nginx配置文件

nginx -s reload

查看端口,8000已经为nginx接管了

root@ubuntu:/etc/nginx/sites-enabled# netstat -anpt|grep 8000  tcp        0      0 0.0.0.0:8000            0.0.0.0:*               LISTEN      18895/nginx -g daem  tcp        0      0 192.168.10.102:8000     192.168.10.105:52556    ESTABLISHED 19135/nginx: worker  tcp        0      0 192.168.10.102:8000     192.168.10.105:52557    ESTABLISHED 19135/nginx: worker

刷新页面,效果同上!

进入目录 /www/mysite1/static ,放一张图片 girl.jpg

访问图片

http://192.168.10.102:8000/static/girl.jpg

效果如下:

本文参考链接:

http://www.py3study.com/Article/details/id/323.html

https://www.jianshu.com/p/07458e99198a