美文网首页
Django部署到Apache

Django部署到Apache

作者: YellowTag | 来源:发表于2020-01-19 01:57 被阅读0次

    部署大概流程

    前言

    在这一路部署上来,花了我大概两天多的时间,现在总结想想原因,大部分时间是用在补版本问题的坑上面,然后我的情况又有一点特殊,我的云服务器上原来装的是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字样的文件

    结果
    从其中我们能看到在这个目录下有一个叫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.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

          本文链接:https://www.haomeiwen.com/subject/subkzctx.html