宝塔面板如何用uwsgi与nginx快速部署Django项目
Posted 幸福关中
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了宝塔面板如何用uwsgi与nginx快速部署Django项目相关的知识,希望对你有一定的参考价值。
Django框架是一个用Python编写的非常出名的web框架,利用Django框架我们可以快速开发出项目,但对于很多不懂运营服务器的小伙伴来说,部署上线应该是遇到坑最多的一个环节,那么我们今天就来学习如何利用强大的宝塔面板来部署Django项目。
一、linux安装宝塔面板
Centos终端安装命令:
yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh
Ubuntu终端安装命令:
wget -O install.sh http://download.bt.cn/install/install-ubuntu_6.0.sh && sudo bash install.sh
二、安装nginx以及mysql
成功登入宝塔面板后,点击侧边栏软件商店栏目,在第一页的下方找到Nginx与Mysql点击安装,如下图所示:
安装Nginx与Mysql
在安装Mysql的时候一定要注意版本问题,Django最新版已经不支持5.5以下版本,我们安装的时候可以选择安装5.6或者5.7版本。
安装Mysql5.7
等待安装完成。
三、安装Python项目管理器
安装Python项目管理器
还是在软件商店栏目下,位于分页第三页,如上图所示,点击安装。
安装成功后,点击设置,在弹出的对话框中,注意左侧侧边栏,有一个版本管理栏目,进入后选择与项目对应的Python版本安装,如下图所示。
安装Python
安装成功之后切换到项目管理栏目,点击添加项目
四、git拉取线上项目,在Python项目管理器添加项目
如果这里你没有项目,可以看看我这个专栏,有兴趣的话一起学习,可私信我,我将这个项目线上仓库推送给你用来测试。
此时你的项目就必须已经存在,可以通过git命令将线上仓库项目拉取到/www/wwwroot文件夹下,或者/home/qbc文件夹下,qbc是我的用户文件,linux所有的组成都是以文件夹的方式归类,用户也是一个文件夹。
按照要求选择对应的版本及文件夹
映射域名
点击映射,绑定一个域名,我这里以本地IP为例子。
之后这里会有个问题,有可能虚拟环境中的uwsgi没有安装成功,通过这一步后,我们就要去终端测试,这里我们手动进入虚拟环境去测试下。
手动进入虚拟环境安装,进入虚拟环境方法:
激活虚拟环境:在命令行输入 source 项目路径/项目名_venv/bin/activate
如我这里:source /home/qbc/coder/mysite/mysite_venv/bin/activate
终端测试uwsgi
我这里uwsgi已经安装成功了,如果未安装成功一般是两种错误提示未安装gcc以及python3-devel
错误一:未安装python3-devel
*** uWSGI compiling embedded plugins ***
[gcc -pthread] plugins/python/python_plugin.o
In file included from plugins/python/python_plugin.c:1:
plugins/python/uwsgi_python.h:2:10: 致命错误:Python.h:没有那个文件或目录
#include <Python.h>
编译中断。
解决办法:
yum install python3-devel # centos系统安装
sudo apt install python3-dev # ubuntu系统安装
错误二:未安装gcc
File "/tmp/pip-build-_3kmen6o/uwsgi/setup.py", line 77, in run
conf = uc.uConf(get_profile())
File "/tmp/pip-build-_3kmen6o/uwsgi/uwsgiconfig.py", line 750, in __init__
raise Exception("you need a C compiler to build uWSGI")
Exception: you need a C compiler to build uWSGI
解决办法:
yum install gcc # centos系统安装
sudo apt-get install gcc # ubuntu系统安装
此时可以进入虚拟环境,通过pip命令安装uwsgi
pip3 install uwsgi
uwsgi安装成功,此时可以运行同步数据库命令。
五、创建默认sqlite3数据库或者配置Mysql数据库
python3 manage.py makemigrations # 创建迁移文件
# 创建sqlite3数据库(这里也最容易出错,一般都是版本问题引起的错误)
python3 manage.py migrate
如果这里操作这两步出现错误问题,那么我们的项目肯定是没办法运行起来的,此时我的做法是直接改用Mysql数据库,还记得刚开始我们已经安装了数据库吗?
创建Mysql数据库
侧边栏点击数据库==>点击添加数据库,如上图所示,按照提示设置数据库用户名密码。
修改项目mysite/settings.py文件的数据库配置项,如下图所示
修改mysite/settings.py数据库配置项
点击左侧文件栏目,找到项目目录settings.py文件,点击编辑,将DATABASES项修改为如下所示配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'mysite', # 数据库名称
'USER': 'mysite', # 用户名称默认是root
'PASSWORD': '123456', # 密码
'HOST': '127.0.0.1', # 默认
'PORT': '3306', # 默认
}
}
激活虚拟环境,安装mysqlclient
pip3 install mysqlclient
这一步如果安装失败,一般是缺少mysiql-devel,安装之后再运行pip命令安装即可解决
yum install mysql-devel
必须进入项目目录,激活虚拟环境,执行同步数据库命令,
python3 manage.py migrate
六、部署静态文件
在mysite/settings.py中添加 STATIC_ROOT = '/home/qbc/coder/mysite/static/'
激活虚拟环境,进入项目文件,运行收集静态文件命令
python3 manage.py collectstatic
进入/www/server/panel/vhost/nginx文件夹,找到映射域名.conf文件,点击编辑,增加静态文件路径,如下图所示:
增加的代码
location /static/ {
alias /home/qbc/coder/mysite/static/;
}
location /media/ {
alias /home/qbc/coder/mysite/media/;
}
文件栏目,增加静态文件路径
之后去到python项目管理器里边,重启项目,找到nginx,点击设置,重启即可访问。
红星照我去奋斗
创作不易,请点在看并分享,这时最大的鼓励!
如果有打赏,么么哒!
以上是关于宝塔面板如何用uwsgi与nginx快速部署Django项目的主要内容,如果未能解决你的问题,请参考以下文章