Django部署到Apache
部署大概流程
前言
在这一路部署上来,花了我大概两天多的时间,现在总结想想原因,大部分时间是用在补版本问题的坑上面,然后我的情况又有一点特殊,我的云服务器上原来装的是linux宝塔
,图个方便,用时一时爽,******。后来在配置的时候,很多地方有点受到限制,比如mod_wsgi在宝塔上用不了,如果要用必须要想办法把库装到宝塔自带的lib里面,于是我就干脆直接用命令行进行部署,本来不想卸载宝塔的,后来出现端口占用问题,解决后还是一堆问题,就直接卸载宝塔了。
流程
Apache在部署python支持的django时,需要WSGI(一个python的网关协议),大概就是:
- 告诉Apache的站点conf(配置文件)去某个路径找到Django项目
为了能实现这种映射,就需要WSGI
- Django项目要允许Apache的访问
本质上就这两步,但过程中可能会有一大堆报错,我在后面会把我部署过程中的错误列举出来,希望能帮到你们。
下面我会说明部署过程中的具体步骤,为了方便,我会省去一些暂时不必要的步骤,这样能快速地理解部署的原理。
先说明一些配置版本
- 阿里云服务器(Ubuntu 18.04)
- python3
- Django3
- Apache2
详细步骤
1.1 使用命令查看服务器电脑的python版本
ls -l /usr/bin | grep python
ls -l
是指在指定目录下以长格式形式显示所有可见文件的详细属性
grep python
是正则表达式,代表匹配含python字样的文件
从其中我们能看到在这个目录下有一个叫python的文件,实际上是链接文件,inode里面存的是python2.7文件的路径(操作系统中成为软链接)
这个地方python文件就是默认的python执行路径,因此,系统默认的python版本就是2.7
1.2 更换python版本
首先删除python这个链接文件(到/usr/bin目录下):
rm -rf python
然后重新生成新的python链接文件:
ln -s /usr/bin/python3.6 /usr/bin/python
说明一下这个命令,格式是: ln -s 源文件 链接文件
意思是创建一个链接文件,共享的是源文件
然后我们在用python命令查看版本:
版本更换成功
这样我们就成功的修改了系统默认的python版本。这里要提一点,我用的3.6,如果想用3.7的话可以自行下载。再者,网上的其他的教程说修改~/.bashrc
文件可以更换python版本,虽然原理上我目前还不太清楚,但是我这样做过,最后Django启动的还是python2.7版本,这意味着这种修改方式只是改了别名而已,/user/bin/python指向的还是2.7版本,所以建议不要这样修改。
2. 安装必要的库
2.1 首先更新下(不是root用户就加上sudo)
apt-get update
2.2 安装pip3(这样下载下来的Django版本比较新,和我写的时候一样,可见MDN-Django教程)
apt-get install python3-pip
2.3 安装Django
pip3 install django
查看django版本:
python -m django --version
3.0.2
2.4 安装mod_wsgi
# Python 2
sudo apt-get install libapache2-mod-wsgi
# Python 3
sudo apt-get install libapache2-mod-wsgi-py3
这里我是python3,故用第二个,这里要注意的是一定要注意版本的对应!我的问题就出现在这里,并不是因为不知道要对应,而是当时没有用软链接的方式修改python默认版本,而是修改.bashrc文件,导致出现问题。
2.5 安装apache
apt-get install apache2
查看apache服务器状态(running就对啦):
systemctl status apache
如果报错了,可以根据命令行的提示来查看报错journal,我的问题是端口被占用了(原因是宝塔)
查看版本:
apachectl -v
Server version: Apache/2.4.29 (Ubuntu)
Server built: 2019-09-16T12:58:48
3. 在服务器上建立一个新的网站
vim /etc/apache2/sites-available/yoursitename.conf
在 /etc/apache2/sites-available目录下我们创建一个新的配置文件(名字自定,就是你网站的配置了)
内容:
<VirtualHost *:80>
#可以写域名或者说你的ip地址
ServerName www.yourdomain.com
ServerAlias otherdomain.com
#差不多是作者的意思
ServerAdmin tuweizhong@163.com
#静态文件的配置(暂时加上去,不过不用管)
Alias /media/ /home/tu/blog/media/
Alias /static/ /home/tu/blog/static/
<Directory /home/tu/blog/media>
Require all granted
</Directory>
<Directory /home/tu/blog/static>
Require all granted
</Directory>
#最关键的 将根目录/ 映射到Django项目位置里面的wsgi.py文件
WSGIScriptAlias / /home/tu/blog/blog/wsgi.py
<Directory /home/tu/blog/blog>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
</VirtualHost>
将我的注释去掉,然后将部分代码路径修改一下就行
如果你的apache版本号是 2.2.x(第二步有方法判断)
用下面的代替 Require all granted
Order deny,allow
Allow from all
4. 修改wsgi.py文件
修改你项目里面wsgi.py文件
import os
from os.path import join,dirname,abspath
PROJECT_DIR = dirname(dirname(abspath(__file__)))#3
import sys # 4
sys.path.insert(0,PROJECT_DIR) # 5
os.environ["DJANGO_SETTINGS_MODULE"] = "blog.settings" # 7
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
第 3,4,5 行(注释)为新加的内容,作用是让脚本找到django项目的位置
需要注意的是代码的顺序(不要直接将新增的内容添加到文本末)
5. 上传你的项目
直接用github的方式上传
若没有安装git,则安装
apt-get install git
6. 修改文件的权限
一般目录权限设置为 755,文件权限设置为 644
假如项目位置在 /home/tu/zqxt (在zqxt 下面有一个 manage.py,zqxt 是项目名称)
cd /home/tu/
sudo chmod -R 644 zqxt
sudo find zqxt -type d | xargs chmod 755
要设置权限才能让Apache访问一些文件
7. 激活网站
sudo a2ensite sitename 或 sudo a2ensite sitename.conf
就是激活下你的配置文件
根据提示,可能还要:
systemctl reload apache2.service
8.重启apache服务器
service apache2 restart
然后要注意,每次修改配置文件或者你Django的项目的内容时,都要重启
这样我们就成功啦,去输入你的ip地址就行
如果出现404的问题,检查一下conf文件Servname字段是不是写的你的ip地址或者域名
如果出现500服务器的错误,可以用命令:
cat /var/log/apache2/error.log
查看具体的错误
当然这里还没讲完,只是最简单的说了下部署的过程,当你搞定之后,还要解决静态文件的问题,以及上传,数据库的权限。
未完待续。。
以下内容不重要
更换ubuntu的python版本
默认情况下版本是2,查看全部的版本
ls -l /usr/bin | grep python
由于python版本引起的错误
1.Django导入不了path
image.png2.查看系统中python命令对应的版本
ls -l /usr/bin/python*
3.查看apache报错日志
cat /var/log/apache2/error.log
4.删除python2版本的mod_wsgi
apt-get remove libapache2-mod-wsgi