原创内容,转载请注明出处,谢谢!
前言
最近想要在阿里云服务器通过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以及权限问题,配置中会出现很多坑。同时网上的资料比较老且零散,所以整个流程顺利完成花费了我挺长时间的。这一教程是我完整走完并且可以成功运行的,大家根据这一教程可以少踩很多坑!初次发教程,如有不足还请指正。转载请注明出处!