• django+nginx+uwsgi 项目部署


      Django虽然自带一个Server,但只能作为开发时测试使用,我们需要一个可以稳定而持续的服务器对网站进行部署,比如Apache, Nginx, lighttpd等,本篇将利用nginx和uWSGI部署Django网站项目。

    前言

    nginx简介

      nginx是一个HTTP服务器,也是一个反向代理服务器,由基础模块、核心模块、第三方模块构成,与Apache相比更轻量级,占用更少的内存及资源。

    WSGI/uWSGI/uwsgi区别

    WSGI(Python Web Server GateWay Interface): WSGI是一种Web服务器网关接口。它是一个Web服务器(如nginx)与应用服务器(如uWSGI服务器)通信的一种规范。由于WSGI的通用性,出现了独立的WSGI程序,例如uWSGI和Apacke的mod_wsgi。

    uWSGI: 是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。用于接收前端服务器转发的动态请求并处理后发给 web 应用程序。

    uwsgi: 是uWSGI服务器实现的独有的协议。

    nginx/uWSGI/Django项目工作流程

    1. 用户通过浏览器发出http请求到服务器。
    2. nginx负责接受外部http请求并进行解包,若请求是静态文件则根据设置好的静态文件路径返回对应内容。若请求是动态内容则将请求交给uWSGI服务器(nginx和uWSGI使用端口或socket通信)。
    3. uWSGI服务器收到请求后,根据wsgi协议解析并回调Django应用。
    4. Django应用则根据请求进行数据库增删查改和模版渲染等工作,然后再逆方向返回nginx。
    5. nginx将响应交付用户浏览器。

    服务器Django+uWSGI+nginx配置(上)

      前面4.1小结,我们利用在/var/www/下git clone了一个空仓库,假设名为”com.test.blog“,实际上是一个进行了git初始化的空文件夹。

    创建项目虚环境

        $ sudo -s                       // 获得root权限
        $ cd /var/www/com.test.blog     // 进入项目文件夹
        $ virtualenv env --python=python2.7 
                    --no-site-packages  // 创建名为env的python空环境

      如果产生如下报错,说明服务器语言未设置。

    locale.Error: unsupported locale setting

      则先执行

        $ export LC_ALL=C

      后再次执行上述命令。

    Django部分

    安装Django

      启用env环境。

        $ source env/bin/activate       // 启用环境

      安装支持python2.7的Django 1.11。

        $ pip install Django==1.11
        $ django-admin --version

    创建一个Django默认项目用于测试

        $ django-admin startproject test_nginx
                        // 创建名为“test_nginx”的Django项目

      Django会用模板创建一个名为“test_nginx”的默认项目。

    Django 测试项目

    测试Django服务器

      利用Django自带的测试服务器来直接处理客户端的http访问请求,测试Django能否正常工作。

    Django Server

      注意,首先要修改settings.py配置文件,添加ALLOWED_HOSTS,否则会报错。
      进入./test_nginx/test_nginx,利用vim修改settings.py中的“ALLOWED_HOSTS”。

        ...
    
            ALLOWED_HOSTS = ['*']   // 允许所有地址
    
        ...

      这样可以在本地直接利用服务器ip和端口访问网页了。
      
      运行Django Server(Ctrl + C 结束运行)。

        $ pwd           // 当前路径
                /var/www/com.test.blog/test_nginx
        $ python manage.py runserver 0.0.0.0:8000
                        // 8000端口,启用Django服务器

      本地浏览器输入”服务器IP:8000”,显示

    Django welcome页面

    uWSGI部分

    安装uWSGI

      在env虚拟环境下使用pip安装。

        $ pip install uwsgi
        $ uwsgi --version       // 显示uwsgi安装版本

    测试uWSGI服务器

      新建test.py文件,内容如下:

    def application(env, start_response):
        start_response('200 OK', [('Content-Type','text/html')])
        return "Hello World from uWSGI"

      终端运行:

        $ uwsgi --http :8000 --wsgi-file test.py
    • 1

      本地浏览器刷新页面,显示

    uWSGI welcome页面

    uWSGI+Django测试

      利用uWSGI作为服务器处理http请求,并通过wsgi传递给Django模块。

    uWSGI+Django
      终端运行:

        $ pwd
            /var/www/com.test.blog/test_nginx
        $ uwsgi --http :8000 --module test_nginx.wsgi

      本地浏览器刷新页面,显示

    Django welcome页面

    nginx部分

    安装nginx

        $ sudo apt install nginx

    nginx常用命令

    启动nginx服务器

        $ sudo service nginx start

    停止nginx服务器

        $ sudo service nginx stop

    查看nginx服务的状态

        $ sudo service nginx status

    重启nginx服务器

        $ service nginx restart

    测试nginx服务器状态

      启动nginx服务器后,本地浏览器输入”服务器IP:80”,如下图显示说明nginx工作正常。
      
    nginx welcome页面

    结语

      服务器端nginx,uWSGI和Django彼此之间已经可以独立工作,下半篇将修改配置文件,真正使nginx作为Django网站项目的代理服务器。

    参考文献

    1. WSGI,uwsgi和uWSGI的区别
    2. 使用uWSGI和nginx来设置Django和你的web服务器
  • 相关阅读:
    监控组策略应用组策略建模
    win7加域出现桌面文件丢失和映射驱动器丢失解决办法
    通过windows server 2008 AD域服务器之组策略关闭默认windows共享
    Win 2008 R2 AD组策略统一域用户桌面背景
    Win7+Ubuntu11.10(EasyBCD硬盘安装)
    组策略复制失败排错思路实例
    Windows Server 2008 R2搭建域环境中遇到的一个小错误的解决办法
    通过windows server 2008 AD域服务器之组策略关闭默认windows共享
    无需写try/catch,也能正常处理异常
    [原]《Web前端开发修炼之道》读书笔记JavaScript部分
  • 原文地址:https://www.cnblogs.com/mosson/p/9205633.html
Copyright © 2020-2023  润新知