使用宝塔面板部署Django应用(不成功Kill Me!)

使用宝塔面板部署Django应用

文章目录

本地操作

  1. 备份数据库
shell 复制代码
# 备份数据库
mysqldump -u root -p blog > blog.sql
  1. 创建requirements
shell 复制代码
# 创建requirements.txt
pip freeze > requirements.txt
  1. 将本项目打包成zip文件上传到服务器

宝塔面板部署

  1. 进入宝塔面板 在软件商店安装Myql5.7 python项目管理器2.4 Nginx1.24
  1. 在网站栏点击添加站点 输入域名 其他都不创建
  1. 然后点击数据库栏点击添加数据库,一般数据库名就用django应用的数据库名

然后导入刚才备份的数据库sql文件

  1. 然后将刚才上传的zip文件解压到www/wwwroot目录下,然后修改配置文件

修改settins.py文件,注意这里的密码就是刚才创建数据库时生成的密码

python 复制代码
# 修改数据库配置
DATABASES = {
    "default": {
        "ENGINE": "django.db.backends.mysql",
        'USER': 'blog_project',
        'PASSWORD': 'xxxxx',
        'HOST': 'localhost',
        'PORT': '3306',
        'NAME': 'blog_project',
    }
}

在根目录下创建uwsgi.ini文件,复制内容

ini 复制代码
[uwsgi]
master = true
processes = 1
threads = 2
master = true
chdir = /www/wwwroot/blog_project
wsgi-file= /www/wwwroot/blog_project/blog_project/wsgi.py
http = 0.0.0.0:8000
logto = /www/wwwroot/blog_project/logs/error.log
chmod-socket = 660
vacuum = true
uid=root
gid=root
max-requests = 1000
  1. 点击软件商店,点击python项目管理器的设置,点击添加项目

注意这里项目路径要填到manage.py文件的上一级目录,也就是项目的根目录,确保这里面有requirements.txt文件和manage.py文件。

启动文件要选择wsgi.py文件

  1. 映射到域名,输入刚才设置的域名即可
  1. 修改一下nginx的配置文件,将域名指向到django的端口
  1. 重启nginx和python项目管理器,然后访问域名,如果出现主页,说明部署成功

可能部署失败的情况

如果出现诸如502 或者 Internal Server Error等错误,大概率是setting.py文件中的数据库配置有问题.(如果你照着我的步骤操作的话)

如果出现页面加载成功,但是样式、图片等资源加载不出来,可能是静态资源没有配置好,具体来说就是在nginx的配置文件中加入

nginx 复制代码
location /static/ {
    alias /www/wwwroot/blog_project/static/;
}

如果出现404错误,可能是python项目忘记启动,重启一下即可。

相关推荐
keke102 分钟前
Java【10_1】用户注册登录(面向过程与面向对象)
java·python·intellij-idea
呦呦鹿鸣Rzh11 分钟前
redis
数据库·redis·缓存
xiaogai_gai19 分钟前
有效的聚水潭数据集成到MySQL案例
android·数据库·mysql
微刻时光1 小时前
影刀RPA网页自动化总结
运维·人工智能·python·低代码·自动化·rpa·影刀rpa
web130933203981 小时前
Mysql的安装配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
数据库·mysql
三天不学习1 小时前
浅析AI大模型为何需要向量数据库?【入门基础】
数据库·人工智能·欧氏距离·向量数据库·余弦相似度
MonkeyKing_sunyuhua1 小时前
将数据库结构化数据整合到RAG问答中的方式
数据库
喝醉酒的小白1 小时前
MySQL内存使用率高问题排查与解决方案:
数据库
鹅鹅鹅呢1 小时前
mysql 登录报错:ERROR 1045(28000):Access denied for user ‘root‘@‘localhost‘ (using password Yes)
android·数据库·mysql
摘星编程1 小时前
Redis+Caffeine构建高性能二级缓存
数据库·redis·缓存