Linux--部署Django+DRF+vue项目

简介: Linux--部署Django+DRF+vue项目

前戏


在nginx里已经部署了前端项目,现在还需要部署后端项目

后端项目使用django+DRF,虚拟环境用的 pipenv

配置数据库,安装依赖环境等省略


部署


拉取最新的代码

git pull origin master

进入虚拟环境

pipenv shell

安装uwsgi

[root@HH ManageSystem]# pipenv install -i https://pypi.douban.com/simple uwsgi

ManageSystem为我的django项目名,表明我现在在项目的根目录下。

查看版本,注意要在虚拟环境里执行

(ManageSystem) [root@HH ManageSystem]# uwsgi --version
2.0.19.1

启动项目测试,ManageSystem为你的项目名

(ManageSystem) [root@HH ManageSystem]# uwsgi --http :8081 --module ManageSystem.wsgi

postman访问接口测试


配置nginx


部署VUE项目后的配置文件

View Code

在配置nginx之前,先创建一个 uwsgi.ini 的文件,和 manage.py 文件同级

里面内容如下

[uwsgi]
#项目的绝对路径,定位到项目的第一层
chdir           = /opt/ManageSystem
#指明项目的wsgi文件路径
module          =ManageSystem.wsgi
#指明你的虚拟解释器的第一层路径
home            = /root/Envs/ManageSystem-t7qCu0Kd
#指明通过uwsgi,启动多少个进程
processes       = 5
#如果你已经配置了nginx(启动了nginx服务,配置了uwsgi_pass),请用这个socket连接
socket          = 0.0.0.0:8082   # 使用这个,将下面的http注释掉
#如果你没用nginx,想通过uwsgi直接启动web服务,指明http协议
#http = 0.0.0.0:9999
#在退出uwsgi环境后,清空环境变量
vacuum          = true

home   = /root/Envs/ManageSystem-t7qCu0Kd 可以使用 pipenv --venv 查看

socket      = 0.0.0.0:8082  这个的端口不是你接口的端口,和nginx里的代理均衡的一样

配置好 uwsig.ini之后再来配置 nginx

[root@HH conf]# vim nginx.conf

完整的配置如下

nginx.conf

检查nginx配置文件,加载配置文件,重启nginx

[root@HH conf]# cd ../sbin/
[root@HH sbin]# ./nginx -t  # 检查配置文件的语法
nginx: the configuration file /opt/nginx1-16//conf/nginx.conf syntax is ok
nginx: configuration file /opt/nginx1-16//conf/nginx.conf test is successful
[root@HH sbin]# ./nginx -s reload  # 加载配置文件
[root@HH sbin]# ./nginx  # 重启nginx
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:8081 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:8081 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:8081 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:8081 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
nginx: [emerg] bind() to 0.0.0.0:8081 failed (98: Address already in use)
nginx: [emerg] still could not bind()

启动uwsgi.ini

(ManageSystem) [root@HH ManageSystem]# uwsgi --ini uwsgi.ini

访问接口

 

这样启动的只是在前台运行,当窗口关闭之后,就访问不了了,我们使用nohup在后台运行

(ManageSystem) [root@HH ManageSystem]# nohup uwsgi --ini uwsgi.ini &

注意:在当shell中提示了nohup成功后,还需要按终端上键盘任意键退回到shell输入命令窗口,然后通过在shell中输入exit来退出终端;如果在nohup执行成功后直接点关闭程序按钮关闭终端的话,这时候会断掉该命令所对应的session,导致nohup对应的进程被通知需要一起shutdown,起不到关掉终端后调用程序继续后台运行的作用。


相关实践学习
CentOS 8迁移Anolis OS 8
Anolis OS 8在做出差异性开发同时,在生态上和依赖管理上保持跟CentOS 8.x兼容,本文为您介绍如何通过AOMS迁移工具实现CentOS 8.x到Anolis OS 8的迁移。
相关文章
|
1月前
|
消息中间件 Linux
Linux:进程间通信(共享内存详细讲解以及小项目使用和相关指令、消息队列、信号量)
通过上述讲解和代码示例,您可以理解和实现Linux系统中的进程间通信机制,包括共享内存、消息队列和信号量。这些机制在实际开发中非常重要,能够提高系统的并发处理能力和数据通信效率。希望本文能为您的学习和开发提供实用的指导和帮助。
122 20
|
4月前
|
存储 数据可视化 Java
震惊!如何在linux下部署项目,部署/运行jar包 超详细保姆级教程!
如何在Linux系统下部署和运行Java项目jar包,包括传输文件到Linux、使用nohup命令运行jar包、查看端口状态、杀死进程和查看项目运行状态,以及如何解决“没有主清单属性”的错误。
921 2
震惊!如何在linux下部署项目,部署/运行jar包 超详细保姆级教程!
|
4月前
|
关系型数据库 MySQL Linux
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
907 3
|
4月前
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
1025 3
|
4月前
|
JavaScript 前端开发 API
vue获取图片的blob传给django后端
vue获取图片的blob传给django后端
107 4
|
4月前
|
JavaScript 前端开发 Python
django接收前端vue传输的formData图片数据
django接收前端vue传输的formData图片数据
87 4
|
4月前
|
算法 Java Linux
java制作海报五:java 后端整合 echarts 画出 折线图,项目放在linux上,echarts图上不显示中文,显示方框口口口
这篇文章介绍了如何在Java后端整合ECharts库来绘制折线图,并讨论了在Linux环境下ECharts图表中文显示问题。
90 1
|
4月前
|
前端开发 JavaScript 应用服务中间件
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
本文是一篇详细的教程,介绍了如何在Linux系统上安装和配置nginx,以及如何将打包好的前端项目(如Vue或React)上传和部署到服务器上,包括了常见的错误处理方法。
1298 0
linux安装nginx和前端部署vue项目(实际测试react项目也可以)
|
4月前
|
监控 应用服务中间件 网络安全
部署Django应用:使用Gunicorn和Nginx构建高效的生产环境
部署Django应用:使用Gunicorn和Nginx构建高效的生产环境
277 0
|
2月前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
151 1