CentOS上部署Django

作者: 木头lbj | 来源:发表于2016-09-28 03:15 被阅读2564次

    搭建Python环境

    一般云服务(如阿里云)的CentOS系统默认的Python版本较低,还停留在2.6。如果是这样,首先需要搭建较高版本的Python环境。具体可以参见之前翻译的博文在CentOS 6.4上设置Python2.7.6和3.3.3环境

    依次执行以下命令:

    yum install -y update  # 更新内置程序
    yum groupinstall -y development  # 安装所需的development tools
    yum install -y zlib-dev openssl-devel sqlite-devel bzip2-devel  # 安装附加包  
    yum install xz-libs  # 安装XZ解压库(可选)
    
    wget http://www.python.org/ftp/python/2.7.6/Python-2.7.6.tar.xz  # 下载源码包 
    
    # 解压源码包,分为两步  
    xz -d Python-2.7.6.tar.xz  
    tar -xvf Python-2.7.6.tar  
    
    # 编译与安装,先进入源码目录  
    cd Python-2.7.6  
    ./configure --prefix=/usr/local  
    make  
    make altinstall  
    
    # 配置virtualenv虚拟环境  
    wget --no-check-certificate https://pypi.python.org/packages/source/s/setuptools/setuptools-1.4.2.tar.gz  
    tar -xvf setuptools-1.4.2.tar.gz  
    cd setuptools-1.4.2  
    python2.7 setup.py install  
    curl https://raw.githubusercontent.com/pypa/pip/master/contrib/get-pip.py | python2.7 -  
    pip install virtualenv  
    
    # 创建项目所需的虚拟环境venv  
    virtualenv venv --python=`which python2.7`
    
    # 修改.bashrc,在该系统用户登录之后自动激活虚拟环境。
    # 在.bashrc下增加以下命令    
    source ~/venv/bin/activate  
    
    

    安装数据库MySQL

    使用yum源直接安装的版本较低,一般需要安装较高版本(5.5及以上)。

    # 添加yum源  
    ## Remi Dependency on CentOS 5 and Red Hat (RHEL) 5 ##
    rpm -Uvh http://dl.fedoraproject.org/pub/epel/5/i386/epel-release-5-4.noarch.rpm
    
    ## CentOS 5 and Red Hat (RHEL) 5 ## 
    rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-5.rpm
    
    rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noarch.rpm
    rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-6.rpm  
    
    # 检查可用的MySQL版本  
    yum --enablerepo=remi,remi-test list mysql mysql-devel mysql-server  
    
    # 安装MySQL  
    yum --enablerepo=remi,remi-test install mysql mysql-server  
    
    # 修改/etc/my.conf,修改或者添加以下配置,支持unicode全字符(即支持emoji)
    [client]
    default-character-set = utf8mb4
    [mysqld]
    character-set-server = utf8mb4
    collation-server = utf8mb4_unicode_ci
    default-storage-engine = INNODB
    
    # 启动MySQL  
    service mysqld start  
    
    # 检查配置是否正确
    mysql -u root -p   # 回车,不需要输入密码,此时还未设置root密码
    mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';  
    
    # 如果看到以下结果说明配置正确  
    +--------------------------+--------------------+
    | Variable_name            | Value              |
    +--------------------------+--------------------+
    | character_set_client     | utf8mb4            |
    | character_set_connection | utf8mb4            |
    | character_set_database   | utf8mb4            |
    | character_set_filesystem | binary             |
    | character_set_results    | utf8mb4            |
    | character_set_server     | utf8mb4            |
    | character_set_system     | utf8               |
    | collation_connection     | utf8mb4_general_ci |
    | collation_database       | utf8mb4_unicode_ci |
    | collation_server         | utf8mb4_unicode_ci |
    +--------------------------+--------------------+
    
    # 查看用户信息  
    mysql> SELECT user,host,password FROM mysql.user;
    +------+--------------+----------+
    | user | host         | password |
    +------+--------------+----------+
    | root | localhost    |          |
    | root | iz2853tmsqfz |          |
    | root | 127.0.0.1    |          |
    |      | localhost    |          |
    |      | iz2853tmsqfz |          |
    +------+--------------+----------+
    
    # 设置root用户密码  
    mysqladmin -u root password 'password'  
    
    # 使用root用户登录后创建新用户  
    mysql> CREATE USER 'demouser'@'localhost' IDENTIFIED BY 'demopassword';
    
    # 授权  
    mysql> GRANT ALL PRIVILEGES ON demodb.* to demouser@localhost;
    mysql> FLUSH PRIVILEGES;
    
    # 使用新创建的用户登录后创建数据库  
    mysql> CREATE DATABASE demodb;
    
    

    拉取项目代码并安装所需包

    # 安装数据库MySQL  
    yum install mysql  
    
    # 拉取项目代码(示例使用git),假设项目名为proj  
    git clone 代码库地址  
    
    # 安装requirements.txt中所有的包  
    pip install -r requirements.txt
    

    注意 如果出现以下错误:

    _mysql.c:2654: error: '_mysql_ResultObject' has no member named 'converter'
        _mysql.c:2654: error: initializer element is not constant
        _mysql.c:2654: error: (near initialization for '_mysql_ResultObject_memberlist[0].offset')
        _mysql.c:2661: error: '_mysql_ResultObject' has no member named 'has_next'
        _mysql.c:2661: error: initializer element is not constant
        _mysql.c:2661: error: (near initialization for '_mysql_ResultObject_memberlist[1].offset')
        _mysql.c: In function '_mysql_ConnectionObject_getattro':
        _mysql.c:2680: error: '_mysql_ConnectionObject' has no member named 'open'
        error: command 'gcc' failed with exit status 1
    

    一般上述错误可以使用yum install mysql-devel 解决,但是由于这里添加了源来安装MySQL,所以版本会不正确,出现以下错误:

    Error: Package: mysql-devel-5.1.73-7.el6.x86_64 (base)
               Requires: mysql = 5.1.73-7.el6
               Installed: mysql-5.5.52-1.el6.remi.x86_64 (@remi)
                   mysql = 5.5.52-1.el6.remi
               Available: mysql-5.1.73-7.el6.x86_64 (base)
                   mysql = 5.1.73-7.el6
     You could try using --skip-broken to work around the problem
     You could try running: rpm -Va --nofiles --nodigest
    

    解决方法:

    yum --enablerepo=remi,remi-test install mysql-devel
    

    配置gunicorn

    # gunicorn_start.sh  
    #!/bin/bash
    
    NAME="demo"
    DJANGODIR=/path/to/your/project/
    SOCKFILE=/tmp/gunicorn.sock
    USER=user
    GROUP=group
    NUM_WORKERS=2
    DJANGO_SETTINGS_MODULE=demo.settings
    DJNAGO_WSGI_MODULE=demo.wsgi
    
    cd $DJANGODIR
    source /path/to/your/venv/bin/activate
    export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
    export PYTHONPATH=$DJANGODIR:$PYTHONPATH
    
    exec /path/to/your/venv/bin/gunicorn demo.wsgi:application \
        --name $NAME \
        --workers $NUM_WORKERS \
        --bind=unix:$SOCKFILE \
        --log-level=debug \
        --log-file=/path/to/logs/bootcamp_gunicorn.log
    

    配置supervisor

    pip install supervisor
    
    echo_supervisord_conf > /path/to/conf/supervisord.conf  
    
    # 将以下配置加入supervisord.conf中  
    [program:demo]
    command = sh /path/to/gunicorn_start.sh
    user = user
    stdout_logfile = /path/to/logs/gunicorn_supervisor.log
    redirect_stderr = true
    environment=LANG=en_US.UTF-8,LC_ALL=en_US.UTF-8
    
    # 启动supervisord
    supervisord -c /path/to/supervisord.conf
    
    # 重新加载配置
    supervisorctl -c /path/to/supervisord.conf reload
    
    # 重启程序  
    supervisorctl -c /path/to/supervisord.conf restat demo  
    
    # 查看程序运行状态  
    supervisorctl -c /path/to/supervisord.conf status demo
    

    配置Nginx

    # 安装Nginx  
    yum install nginx
    
    # /etc/nginx/conf.d/demo.conf文件中写入以下配置  
    upstream demo_server {
        server unix:/path/to/gunicorn.sock fail_timeout=0;
    }
    
    server {
    
          listen       8888;
          server_name  example.com;
          access_log   /path/to/logs/nginx/access.log;
          error_log    /path/to/logs/nginx/error.log;
    
          location  /static/ {
              root /path/to/demo;
          }
    
          location  / {
              proxy_redirect        off;
              proxy_set_header      Host             $host;
              proxy_set_header      X-Real-IP        $remote_addr;
              proxy_set_header      X-Forwarded-For  $proxy_add_x_forwarded_for;
              client_max_body_size  10m;
    
              if (!-f $request_filename) {
                  proxy_pass http://demo_server;
                  break;
              }
          }
    
      }
      
      # 启动/重启Nginx
      /etc/init.d/nginx start|restart
      
      # reload 配置  
      /etc/init.d/nginx reload
    

    数据表创建与静态文件处理

    # 创建数据库  
    mysql> create database demo;
    
    # migrate  
    python manage.py migrate  
    
    # collectstatic
    python manage.py collectstatic
    

    相关文章

      网友评论

        本文标题:CentOS上部署Django

        本文链接:https://www.haomeiwen.com/subject/vcshyttx.html