zoukankan      html  css  js  c++  java
  • Django Nginx+uwsgi 安装配置

    Django Nginx+uwsgi 安装配置

    在前面的章节中我们使用 python manage.py runserver 来运行服务器。这只适用测试环境中使用。

    正式发布的服务,我们需要一个可以稳定而持续的服务器,比如apache, Nginx, lighttpd等,本文将以 Nginx 为例。

    可直接参考:Python uwsgi 安装配置

    安装基础开发包

    Centos 下安装步骤如下:

    yum groupinstall "Development tools"
    yum install zlib-devel bzip2-devel pcre-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel
    

    CentOS 自带 Python 2.4.3,但我们可以再安装Python2.7.5:

    cd ~
    wget http://python.org/ftp/python/2.7.5/Python-2.7.5.tar.bz2
    tar xvf Python-2.7.5.tar.bz2
    cd Python-2.7.5
    ./configure --prefix=/usr/local
    make && make altinstall
    

    安装Python包管理

    easy_install 包 https://pypi.python.org/pypi/distribute

    安装步骤:

    cd ~
    wget https://pypi.python.org/packages/source/d/distribute/distribute-0.6.49.tar.gz
    tar xf distribute-0.6.49.tar.gz
    cd distribute-0.6.49
    python2.7 setup.py install
    easy_install --version
    

    pip 包: https://pypi.python.org/pypi/pip

    安装 pip 的好处是可以用 pip list、pip uninstall 管理 Python 包, easy_install 没有这个功能,只有 uninstall。


    安装 uwsgi

    uwsgi:https://pypi.python.org/pypi/uWSGI

    uwsgi 参数详解:http://uwsgi-docs.readthedocs.org/en/latest/Options.html

    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"
    

    然后在终端运行:

    uwsgi --http :8001 --wsgi-file test.py
    

    在浏览器内输入:http://127.0.0.1:8001,查看是否有"Hello World"输出,若没有输出,请检查你的安装过程。


    安装 Django

    pip install django
    

    测试 django 是否正常,运行:

    django-admin.py startproject demosite
    cd demosite
    python2.7 manage.py runserver 0.0.0.0:8002
    

    在浏览器内输入:http://127.0.0.1:8002,检查django是否运行正常。


    安装 Nginx

    安装命令如下:

    cd ~
    wget http://nginx.org/download/nginx-1.5.6.tar.gz
    tar xf nginx-1.5.6.tar.gz
    cd nginx-1.5.6
    ./configure --prefix=/usr/local/nginx-1.5.6 
    --with-http_stub_status_module 
    --with-http_gzip_static_module
    make && make install
    

    你可以阅读 Nginx 安装配置 了解更多内容。


    uwsgi 配置

    uwsgi支持ini、xml等多种配置方式,本文以 ini 为例, 在/etc/目录下新建uwsgi9090.ini,添加如下配置:

    [uwsgi]
    socket = 127.0.0.1:9090
    master = true         //主进程
    vhost = true          //多站模式
    no-site = true        //多站模式时不设置入口模块和文件
    workers = 2           //子进程数
    reload-mercy = 10     
    vacuum = true         //退出、重启时清理文件
    max-requests = 1000   
    limit-as = 512
    buffer-size = 30000
    pidfile = /var/run/uwsgi9090.pid    //pid文件,用于下面的脚本启动、停止该进程
    daemonize = /website/uwsgi9090.log
    

    Nginx 配置

    找到nginx的安装目录(如:/usr/local/nginx/),打开conf/nginx.conf文件,修改server配置:

    server {
            listen       80;
            server_name  localhost;
            
            location / {            
                include  uwsgi_params;
                uwsgi_pass  127.0.0.1:9090;              //必须和uwsgi中的设置一致
                uwsgi_param UWSGI_SCRIPT demosite.wsgi;  //入口文件,即wsgi.py相对于项目根目录的位置,“.”相当于一层目录
                uwsgi_param UWSGI_CHDIR /demosite;       //项目根目录
                index  index.html index.htm;
                client_max_body_size 35m;
            }
        }
    

    你可以阅读 Nginx 安装配置 了解更多内容。

    设置完成后,在终端运行:

    uwsgi --ini /etc/uwsgi9090.ini &
    /usr/local/nginx/sbin/nginx
    

    在浏览器输入:http://127.0.0.1,你就可以看到 django 的 "It work" 了。

    Django Admin 管理工具

    2 篇笔记 写笔记

    1. 安装 uwsgi 如果失败,有可能是缺少Python的头文件和静态库,需要安装开发版本:

      For apt (Ubuntu, Debian...):

    sudo apt-get install python-dev # for python2.x installs
    sudo apt-get install python3-dev # for python3.x installs
    ```

       
    For yum (CentOS, RHEL...):
       
    

    sudo yum install python-devel

    
    For dnf (Fedora...):
    
    

    sudo dnf install python2-devel # for python2.x installs
    sudo dnf install python3-devel # for python3.x installs

    
    For zypper (openSUSE...):
    
    

    sudo zypper in python-devel # for python2.x installs
    sudo zypper in python3-devel # for python3.x installs

    
    2. 非多站模式时 **vhost = true** 和 **no-site = true** 需要注释掉,否则后续 nginx 配置文件中设置的入口文件则不生效,服务器会回应 **Internal Server error**:
    
    

    [uwsgi]
    socket = 127.0.0.1:9090
    master = true //主进程

    vhost = true //多站模式

    no-site = true //多站模式时不设置入口模块和文件

    workers = 2 //子进程数
    reload-mercy = 10
    vacuum = true //退出、重启时清理文件
    max-requests = 1000
    limit-as = 512
    buffer-size = 30000
    pidfile = /var/run/uwsgi9090.pid //pid文件,用于下面的脚本启动、停止该进程
    daemonize = /website/uwsgi9090.log

  • 相关阅读:
    Effective C# 原则37:使用标准的配置机制(译)
    Effective C# 原则31:选择小而简单的函数(译)
    Effective C# 原则24:选择申明式编程而不是命令式编程(译)
    Effective C# 原则34:创建大容量的Web API(译)
    Effective C# 原则27:避免使用ICloneable(译)
    Effective C# 第4章:创建基于二进制的组件(译)
    Effective C# 原则39:使用.Net验证(译)
    Effective C# 原则35:选择重写函数而不是使用事件句柄(译)
    Effective C# 原则25: 让你的类型支持序列化(译)
    Effective C# 原则38:使用和支持数据绑定(译)
  • 原文地址:https://www.cnblogs.com/i969639/p/11200894.html
Copyright © 2011-2022 走看看