Django部署到Apache

部署大概流程

前言

在这一路部署上来,花了我大概两天多的时间,现在总结想想原因,大部分时间是用在补版本问题的坑上面,然后我的情况又有一点特殊,我的云服务器上原来装的是linux宝塔,图个方便,用时一时爽,******。后来在配置的时候,很多地方有点受到限制,比如mod_wsgi在宝塔上用不了,如果要用必须要想办法把库装到宝塔自带的lib里面,于是我就干脆直接用命令行进行部署,本来不想卸载宝塔的,后来出现端口占用问题,解决后还是一堆问题,就直接卸载宝塔了。

流程

Apache在部署python支持的django时,需要WSGI(一个python的网关协议),大概就是:

  1. 告诉Apache的站点conf(配置文件)去某个路径找到Django项目

为了能实现这种映射,就需要WSGI

  1. Django项目要允许Apache的访问

本质上就这两步,但过程中可能会有一大堆报错,我在后面会把我部署过程中的错误列举出来,希望能帮到你们。

下面我会说明部署过程中的具体步骤,为了方便,我会省去一些暂时不必要的步骤,这样能快速地理解部署的原理。

先说明一些配置版本

  1. 阿里云服务器(Ubuntu 18.04)
  2. python3
  3. Django3
  4. Apache2

详细步骤

1.1 使用命令查看服务器电脑的python版本

ls -l /usr/bin | grep python

ls -l是指在指定目录下以长格式形式显示所有可见文件的详细属性
grep python是正则表达式,代表匹配含python字样的文件

Django部署到Apache_第1张图片
结果

从其中我们能看到在这个目录下有一个叫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目录下我们创建一个新的配置文件(名字自定,就是你网站的配置了)

内容:


    #可以写域名或者说你的ip地址
    ServerName www.yourdomain.com
    ServerAlias otherdomain.com
    #差不多是作者的意思
    ServerAdmin [email protected]
   
    #静态文件的配置(暂时加上去,不过不用管)
    Alias /media/ /home/tu/blog/media/
    Alias /static/ /home/tu/blog/static/
  
    
        Require all granted
    
  
    
        Require all granted
    

    #最关键的 将根目录/ 映射到Django项目位置里面的wsgi.py文件
    WSGIScriptAlias / /home/tu/blog/blog/wsgi.py
  
    
    
        Require all granted
    
    

将我的注释去掉,然后将部分代码路径修改一下就行
如果你的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

Django部署到Apache_第2张图片
image.png

2.查看系统中python命令对应的版本

ls -l /usr/bin/python*

3.查看apache报错日志

cat /var/log/apache2/error.log

4.删除python2版本的mod_wsgi

apt-get remove libapache2-mod-wsgi

你可能感兴趣的:(Django部署到Apache)