Centos7+Pyenv+Virtualenv+Python3+Django2+mod_wsgi+Apache2.4(httpd)环境配置(免踩坑)

原创内容,转载请注明出处,谢谢!


前言

最近想要在阿里云服务器通过mod_wsgi将django部署在apache(httpd)上。由于本身不是学习后端,耗费了几天时间才真正部署好(网上教程有很多坑)。因此写出完整教程以供后人免于进坑。本教程以root用户进行操作(更新于2018年10月28日)。

各工具版本

centos7.4
python3.6.7
django2.1.2
mod_wsgi4.6.4
apache(httpd)2.4.6

安装pyenv

1. 安装git
sudo yum install git
2. 安装pyenv
git clone git://github.com/yyuu/pyenv.git ~/.pyenv  
echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc  
echo 'export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc  
echo 'eval "$(pyenv init -)"' >> ~/.bashrc  
exec $SHELL -l 

安装python依赖

sudo yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel libpcap-devel xz-devel

安装相应版本python,我这里使用的是3.6.7版本。pyenv支持的版本可以通过如下命令查看:

pyenv install -l

由于pyenv下载python比较慢,可以手动下载想要安装的python,这里以3.6.7版本为例(https://www.python.org/ftp/python/3.6.7/Python-3.6.7.tar.xz)
新建cache文件夹,

mkdir ~/.pyenv/cache

将下载的Python-3.6.7.tar.xz文件放入cache文件夹里。

接下来安装python

env PYTHON_CONFIGURE_OPTS="--enable-shared" pyenv install 3.6.7 -v
注意!一定要使用如上命令安装,否则在安装mod_wsgi时会出现如下错误
/usr/bin/ld: final link failed: Nonrepresentable section on output
或
error: command 'gcc' failed with exit status 1
或
Error : “apxs:Error: Command failed with rc=65536

之后,设置默认python版本为3.6.7

pyenv global 3.6.7

安装httpd(apache)

sudo yum install httpd httpd-devel

重启httpd并设置开机自启

systemctl restart httpd
systemctl enable httpd

这时访问localhost或ip应该可以看到 Testing 123... 的页面,表示httpd安装成功。

安装virtualenv和mod_wsgi

首先安装virtualenv

pip install virtualenv

创建项目目录(随意命名我这里取名wiikvenv)并进入

mkdir /home/wiikvenv
cd /home/wiikvenv

创建独立环境并进入

virtualenv venv
source venv/bin/activate

这时安装mod_wsgi,这里我们通过pip方式安装(PS:网上一大堆安装mod_wsgi的教程都是天坑啊,比如sudo yum install libapache2-mod-wsgi 或 sudo yum install libapache2-mod-wsgi-py3,这样安装会导致后续配置遍地是坑!)

mod_wsgi的正确安装方式如下:
pip install mod_wsgi

最关键一步,分别输入如下语句:

mod_wsgi-express module-config

会返回下列语句,

LoadModule wsgi_module "/home/wiikvenv/venv/lib/python3.6/site-packages/mod_wsgi/server/mod_wsgi-py36.cpython-36m-x86_64-linux-gnu.so"
WSGIPythonHome "/home/wiikvenv/venv"

复制这两句,将其粘贴到/etc/httpd/conf/httpd.conf的最后。
然后执行

chmod 755 -R /root

否则访问域名时不会出现 Testing 123...,并且 /var/log/http/error_log 会出现如下错误。至于为何出现此问题,我也不清楚。。。

Fatal Python error: Py_Initialize: Unable to get the locale encoding
ModuleNotFoundError: No module named 'encodings'

安装django

运行下列命令

pip install django

然后创建django项目,具体教程这里不再赘述,不知道的可以百度一下。
这里假设已经在 /home/wiikvenv 目录下创建了django项目wiik,以及创建了应用wiikapp,并使用django自带的runserver命令可以正常访问。具体目录结构如下:

/home/wiikvenv/wiik
├── wiikapp
│   ├── __init__.py
│   ├── admin.py
│   ├── models.py
│   ├── tests.py
│   ├── static/
│   ├── templates/
│   └── views.py
├── manage.py
└── wiik
    ├── __init__.py
    ├── settings.py
    ├── urls.py
    └── wsgi.py

接下来创建httpd配置文件,如下在 /etc/httpd/conf.d 下新建一个wiik.conf(命名随意)配置文件:

vim /etc/httpd/conf.d/wiik.conf

并且在新文件中输入如下内容:

<VirtualHost *:80>
    ServerName 100.100.100.100 # 你的服务器 ip 地址
    #ServerAlias
    #ServerAdmin 
  
    Alias /static/ /home/wiikvenv/wiik/wiikapp/static/ #如果有静态文件的话,没有则注释掉
   
    <Directory /home/wiikvenv/wiik/wiikapp/static/> # 同上,没有则注释掉
        Require all granted
    </Directory>
  
    WSGIScriptAlias / /home/wiikvenv/wiik/wiik/wsgi.py #django项目中的wsgi.py文件

    WSGIDaemonProcess www-data python-path=/home/wiikvenv/wiik/:/home/wiikvenv/venv/lib/python3.6/site-packages 
    #这句一定要有(因为wsgi.py文件没有修改),
    #并且根据我的目录结构,换成你自己的目录结构,其中 www-data 表示用户(一般不需要修改)
    
    WSGIProcessGroup www-data # 同样必须有
  
    <Directory /home/wiikvenv/wiik/wiik>
    <Files wsgi.py>
        Require all granted
    </Files>
    </Directory>
</VirtualHost>

最后注意输入

chmod 755 -R /home # 即将使用virtualenv创建的独立环境的父目录权限设置为755

否则会出现权限错误:

Forbidden
You don't have permission to access / on this server.

完!

总结

由于python、httpd、django等版本的不同,尤其是httpd以及权限问题,配置中会出现很多坑。同时网上的资料比较老且零散,所以整个流程顺利完成花费了我挺长时间的。这一教程是我完整走完并且可以成功运行的,大家根据这一教程可以少踩很多坑!初次发教程,如有不足还请指正。转载请注明出处!

推荐阅读更多精彩内容