django2.0+nginx+uwsgi配置

此文纯粹记录个人在搭建此博客时候遇到的情况。


django2.0+nginx+uwsgi配置_第1张图片
nginx、uwsgi、django之间的相互联系图

版本说明:

        ubuntu 16.04 64位

        python 3.5

        django 2.0

        kindeditor

        virtualenv 15.2.0

        mysql  5.7.21

        nginx  1.10.3 (Ubuntu)

        uwsgi

主要配置难点在于在django setting.py文件的配置、uwsgi.ini文件配置,nginx配置上。



setting配置

  1.若要放在云服务器上部署。

      ALLOWED_HOSTS = [

              '{云服务器ip地址}',

              '127.0.0.1',

        ]

      首先要对服务器访问ip与web程序进行绑定才可以由云服务器的ip访问web资源。

2.更改数据库配置。

    数据库在云服务器中使用的是mysql,在此建议在安装了mysql后,将云服务器上安装的mysql配置为可远程访问操控,方便在远程使用第三方工具对数据库进行操控。

    DATABASES = {

    'default': {

        # 'ENGINE': 'django.db.backends.sqlite3',

        # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),

        'ENGINE': 'django.db.backends.mysql',

        'NAME': '{数库名}',

        'USER': '{数据库访问用户}',

        'PASSWORD': '{数据库访问密码}',

        'HOST': '{数据库所在的ip地址}',

        'PORT': '3306',

    }

}

使用时,对数据库依赖安装了有以下:

      sudo apt-get build-dep python-lxml   

      pip install PyMSQL

      pip install mysqlclient

      pip install Pollow      ### model中ImageField需要的依赖

3.对静态文件和上传文件的更改。

      django框架下,对静态文件和上传文件是需要进行配置才会有效,要指定访问后缀和文件目录地址,这一切都可以在setting配置中实现。

      #设置静态文件目录。其中前端js、css、kindeditor富文本、UI第三方都放在其中

    #此地址是指在云服务器上 最后所有的static文件夹都会集中在此目录下    运行命令为

python manage.py collectstatic

      MEDIA_ROOT='/var/www/blog/static/'   

      STATIC_URL = '/static/'                          #访问url后缀地址 如  127.0.0.1/static/js/jq.js

      STATICFILES_DIRS = (

            os.path.join(BASE_DIR, "static"),    #开发时存放静态文件目录

      )

      # 设置媒体文件目录  与上静态文件目录配置说明同理

      MEDIA_URL = '/media/'

      MEDIA_ROOT ='/var/www/blog/media/'   

注:admin的静态文件位置与开发时的静态文件位置不一致,所以MEDIA_ROOT来合并所有的静态文件是很有必要的,这样admin才会有样式。



uwsgi 配置

1.基本知识

wsgi:一种实现python解析的通用接口标准/协议,是一种通用的接口标准或者接口协议,实现了python web程序与服务器之间交互的通用性。

利用它,web.py或bottle或者django等等的python web开发框架,就可以轻松地部署在不同的web server上了;

uwsgi:同WSGI一样是一种通信协议

uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型,它与WSGI相比是两样东西。

uWSGI :一种python web server或称为Server/Gateway

uWSGI类似tornadoweb或者flup,是一种python web server,uWSGI是实现了uwsgi和WSGI两种协议的Web服务器,负责响应python 的web请求。

因为apache、nginx等,它们自己都没有解析动态语言如php的功能,而是分派给其他模块来做,比如apache就可以说内置了php模块,让人感觉好像apache就支持php一样。

uWSGI实现了wsgi协议、uwsgi协议、http等协议。 Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。

2.项目运行流程

     .. 首先客户端请求服务资源,

   ..nginx作为直接对外的服务接口,接收到客户端发送过来的http请求,会解包、分析,

   ..如果是静态文件请求就根据nginx配置的静态文件目录,返回请求的资源,

   .. 如果是动态的请求,nginx就通过配置文件,将请求传递给uWSGI;uWSGI 将接收到的包进行处理,并转发给   wsgi,

   .. wsgi根据请求调用django工程的某个文件或函数,处理完后django将返回值交给wsgi,

   .. wsgi将返回值进行打包,转发给uWSGI,

   .. uWSGI接收后转发给nginx,nginx最终将返回值返回给客户端(如浏览器)。

3.实战操作

    安装:sudo pip install uwsgi

    测试uWSGI: 新建文件test.py,写入以下内容:

        def application(env, start_response):

              start_response('200 OK', [('Content-Type','text/html')])

              return "Hello World"

    运行 sudo uwsgi --http 0.0.0.0:8000 --wsgi-file test.py

    若浏览器显示


django2.0+nginx+uwsgi配置_第2张图片
test.py成功相应uwsgi

    在project目录下兴建一个uwsgi.ini文件

            [uwsgi]

            # Django-related settings

            socket = :8000   # Django项目本地端口 

            chdir = /www/Blog/Blog/  # 项目根目录位置

            wsgi-file = /Blog/wsgi.py   # wsgi.py文件在项目的中的相对位置

            module =Blog.wsgi

            # master

            master = true   # 进程设置,无需变动

            # maximum number of worker processes

            processes = 4   # 启动4个uwsgi进程

            # ... with appropriate permissions - may be needed

            # chmod-socket    = 664

            # clear environment on exit

            vacuum = true

            pidfile=uwsgi.pid

            daemonize=uwsgi.log


django2.0+nginx+uwsgi配置_第3张图片
uwsgi.ini文件配置

Nginx配置

    1.作用:

        1. 第一级的nginx并不是必须的,uwsgi完全可以完成整个的和浏览器交互的流程;

        2. 在nginx上加上安全性或其他的限制,可以达到保护程序的作用;

        3. uWSGI本身是内网接口,开启多个work和processes可能也不够用,而nginx可以代理多台uWSGI完成                  uWSGI的负载均衡;

        4. django在debug=False下对静态文件的处理能力不是很好,而用nginx来处理更加高效。

    2.实战配置

        nginx的配置文件在ubuntu中位置为 /etc/nginx/nginx.conf

        而我们要写入的服务配置在  /etc/nginx/sites-enabled/default

        upstream django {

            # 设置本地服务的端口

            server 127.0.0.1:8000; # for a web port socket (we'll use this first)

        }

        # configuration of the server

        server {

            # 监听主机的端口

            listen      80;

            # the domain name it will serve for

            # server_name .liqian.ink; # substitute your machine's IP address or FQDN

            charset    utf-8;

            # max upload size

            client_max_body_size 75M;  # adjust to taste

            # 设置媒体文件目录

            # Django media

            location /media  {

                alias /var/www/blog/media;  # your Django project's media files - amend as required

            }

            # 设置静态文件目录

            location /static {

                alias /var/www/blog/static; # your Django project's static files - amend as required

            }

           # Finally, send all non-media requests to the Django server.

            location / {

                uwsgi_pass  django;

                include    uwsgi_params;         # the uwsgi_params file you installed

        }

    }


django2.0+nginx+uwsgi配置_第4张图片
nginx配置文件写入



备注

1.注意事项

每次修改了Django项目中的模板/视图/URL/配置文件,都需要重启uwsgi服务。

修改Nginx配置文件,都需要重启Nginx服务。

启动:uwsgi --ini uwsgi.ini 

停止:uwsgi --stop uwsgi.pid 

重启:uwsgi --reload uwsgi.pid 

强制停止:killall -9 uwsgi 

nginx -s reload;  nginx重启  但自己常使用 service nginx start/restart/stop

2.文件权限处理

是ubuntu下要先创建关于django web project的静态文件目录和上传文件目录,要保证

修改目录权限:sudo chmod 777 /var/www/xxxx 

创建static目录,注意顺序是先分配权限,再创建目录:mkdir static

你可能感兴趣的:(django2.0+nginx+uwsgi配置)