CentOS上部署Django

搭建Python環(huán)境

一般云服務(如阿里云)的CentOS系統(tǒng)默認的Python版本較低,還停留在2.6。如果是這樣,首先需要搭建較高版本的Python環(huán)境。具體可以參見之前翻譯的博文在CentOS 6.4上設置Python2.7.6和3.3.3環(huán)境。

依次執(zhí)行以下命令:

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虛擬環(huán)境  
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  

# 創(chuàng)建項目所需的虛擬環(huán)境venv  
virtualenv venv --python=`which python2.7`

# 修改.bashrc,在該系統(tǒng)用戶登錄之后自動激活虛擬環(huán)境。
# 在.bashrc下增加以下命令    
source ~/venv/bin/activate  

安裝數(shù)據(jù)庫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用戶登錄后創(chuàng)建新用戶  
mysql> CREATE USER 'demouser'@'localhost' IDENTIFIED BY 'demopassword';

# 授權  
mysql> GRANT ALL PRIVILEGES ON demodb.* to demouser@localhost;
mysql> FLUSH PRIVILEGES;

# 使用新創(chuàng)建的用戶登錄后創(chuàng)建數(shù)據(jù)庫  
mysql> CREATE DATABASE demodb;

拉取項目代碼并安裝所需包

# 安裝數(shù)據(jù)庫MySQL  
yum install mysql  

# 拉取項目代碼(示例使用git),假設項目名為proj  
git clone 代碼庫地址  

# 安裝requirements.txt中所有的包  
pip install -r requirements.txt

注意 如果出現(xiàn)以下錯誤:

_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,所以版本會不正確,出現(xiàn)以下錯誤:

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  

# 查看程序運行狀態(tài)  
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

數(shù)據(jù)表創(chuàng)建與靜態(tài)文件處理

# 創(chuàng)建數(shù)據(jù)庫  
mysql> create database demo;

# migrate  
python manage.py migrate  

# collectstatic
python manage.py collectstatic
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容