nginx+vue+uwsgi+django的前后端分离项目部署
Vue+Django前后端分离项目部署,nginx默认端口80,数据提交监听端口9000,反向代理(uwsgi配置)端口9999
1.下载项目文件(统一在/opt/luffyproject目录)
(1)前端vue--------------wget https://files.cnblogs.com/files/pyyu/07-luffy_project_01.zip
(2)后端django---------wget https://files.cnblogs.com/files/pyyu/luffy_boy.zip
(3)解压-----------------unzip解压(如需实际操作,项目文件可以直接联系博主)
2.vue框架依赖的nodejs
(1)下载nodejs--------wget https://nodejs.org/download/release/v8.6.0/node-v8.6.0-linux-x64.tar.gz
(2)解压-----------------tar -zxvf node-v8.6.0-linux-x64.tar.gz
(3)进入源码包:bin文件夹存在,说明已经编译好,查看是否可用以下命令:
------node -v
------npm -v
(4)添加nodejs源码包bin目录到环境变量:
------vim /etc/profile
------PATH='/opt/tengine231/sbin:/opt/python3.6/bin:/usr/local/sbin:
/usr/local/bin:/usr/sbin:/usr/bin:/root/bin:/root/bin:
/opt/luffyproject/node-v8.6.0-linux-x64/bin'
3.配置前端vue的静态文件请求路径
(1)前端项目/top/luffyproject/07-luffy_project_01/src/restful/api.js
(2)修改api.js中的请求ip和端口----sed -i 's/127.0.0.1:8000/192.168.160.134:9000/g' api.js
(3)注意在项目部署的服务器ip变化时需要更改配置,同时重新执行npm install和 npm run build进行编译生成dist静态文件
4.编译前端vue代码
(1)npm install----网速不好可以先修改npm下载源:npm config set registry https://registry.npm.taobao.org
(2)npm run build--/top/luffyproject/07-luffy_project_01/中种生成一个dist静态文件夹,作为nginx.conf中的server{}匹配的root根目录
(3)注意:如果使用虚拟机,ip可能会自动改变,需重新编译
5.配置nginx.conf
(1)前端vue静态文件返回配置
location / {
root /opt/luffyproject/07-luffy_project_01/dist;
index index.html index.htm;
#确保刷新不出现404
try_files $uri $uri/ /index.html;
}
(2)后端django服务反向代理配置
server {
listen 9000;
server_name localhost;
location / {
include uwsgi_params;
uwsgi_pass 0.0.0.0:9999;
}
}
(3)启动nginx------nginx
6.前端vue静态页面已经部署完成
7.django项目的虚拟环境配置
创建虚拟环境-------mkvirtualenv luffy_env4
已创建有直接开启------workon luffy_env4
8.配置uwgis
(1)进入后端django项目---------cd /opt/luffyproject/luffy_boy
(2)启动测试django项目:
启动django项目---------python3 manage.py runserver 0.0.0.0:9003
报错根据提示在该虚拟环境内处理下载需要的包
pip3 install django==2.0
........
pip3 install -r requirements.txt(批量下载)
(3)下载uwsgi模块 ---------pip3 install uwsgi
(4)手动创建uwsgi.ini文件,写入配置:
[uwsgi]
# Django-related settings
# the base directory (full path)
chdir = /opt/luffyproject/luffy_boy
# Django's wsgi file
module = luffy_boy.wsgi
# the virtualenv (full path)
home = /root/Envs/luffy_env4
# process-related settings
# master
master = true
# maximum number of worker processes
processes = 2
# the socket (use the full path to be safe
#以socket请求与nginx结合
socket = 0.0.0.0:9999
#以http请求可以直接在刘昂器发起访问,测试用
#http =0.0.0.0:9999
# clear environment on exit
vacuum = true
#设置守护进程,后台运行,也可指定文件,输出日志
daemonize=yes
(5)启动uwsgi--------uwsgi --ini uwsgi.ini
(6)uwsgi以http形式进行测试访问:
浏览器直接访问ip端口
部分功能无法实现,缺少redis数据库
(7)物理环境安装redis数据库
yum install redis
systemctl start redis
systemctl status redis
redis-cli--> ping----------启动redis客户端ping是否得到PONG
(8)修改uwsgi.ini以socket形式结合nginx
(9)退出虚拟环境--------deactivate
9.重启nginx--------nginx -s reload
nginx+vue+uwsgi+django的前后端分离项目部署的更多相关文章
- Docker环境下的前后端分离项目部署与运维
本教程将从零开始部署一个前后端分离的开源项目,利用docker虚拟机的容器技术,采用分布式集群部署,将项目转换成为高性能.高负载.高可用的部署方案.包括了MySQL集群.Redis集群.负载均衡.双机 ...
- 前后端分离项目部署到Linux虚拟机
最近做了一个springboot+vue的前后端分离项目,把它部署到Linux虚拟机上.下面是我的步骤和遇到的问题,需要的朋友可以看下(看的时候注意要全部看完到底部,因为我习惯是把我遇到的问题放到最后 ...
- Django前后端分离项目部署
vue+drf的前后端分离部署笔记 前端部署过程 端口划分: vue+nginx的端口 是81 vue向后台发请求,首先发给的是代理服务器,这里模拟是nginx的 9000 drf后台运行在 9005 ...
- vue.js+UEditor集成 [前后端分离项目]
首先,谈下这篇文章中的前后端所涉及到的技术框架内容. 虽然是后端的管理项目,但整体项目,是采用前后端分离的方式完成,这样做的目的也是产品化的需求: 前端,vue+vuex+vue router+web ...
- SpringBoot+Vue豆宝社区前后端分离项目手把手实战系列教程01---搭建前端工程
豆宝社区项目实战教程简介 本项目实战教程配有免费视频教程,配套代码完全开源.手把手从零开始搭建一个目前应用最广泛的Springboot+Vue前后端分离多用户社区项目.本项目难度适中,为便于大家学习, ...
- uwsgi加nginx部署django restframework前后端分离项目
一.uwsgi和nginx简介 1.uwsgi(摘抄于百度百科): uWSGI是一个Web服务器,它实现了WSGI协议.uwsgi.http等协议.Nginx中HttpUwsgiModule的作用是与 ...
- 云计算:Ubuntu下Vue+Springboot前后端分离项目部署(多节点)
一.机器准备 首先准备三台机器: 我是一台WINDOWS系统主机,在WINDOWS里的 VMware 中安装两台Ubuntu系统虚拟机 如果你的虚拟机只有 CentOS,可以参考这篇文章:https: ...
- Docker环境下的前后端分离项目部署与运维(九)后端项目部署与负载均衡
数据库准备 建立数据库 renren_fast ,然后运行renrenfast项目中的db文件夹内的脚本 -- 菜单 CREATE TABLE `sys_menu` ( `menu_id` bigin ...
- SpringBoot+Vue豆宝社区前后端分离项目手把手实战系列教程02---创建后端工程
本节代码开源地址 代码地址 项目运行截图 搭建后端工程 0.导入sql 在数据库导入 /* Navicat Premium Data Transfer Source Server : localhos ...
随机推荐
- Cannot find libcrypto in Ubuntu
https://stackoverflow.com/questions/13811889/cannot-find-libcrypto-in-ubuntu sudo apt-get install li ...
- Unity 游戏框架搭建 2019 (三十九、四十一) 第四章 简介&方法的结构重复问题&泛型:结构复用利器
第四章 简介 方法的结构重复问题 我们在上一篇正式整理完毕,从这一篇开始,我们要再次进入学习收集示例阶段了. 那么我们学什么呢?当然是学习设计工具,也就是在上篇中提到的关键知识点.这些关键知识点,大部 ...
- 在Spring Boot使用H2内存数据库
文章目录 添加依赖配置 数据库配置 添加初始数据 访问H2数据库 在Spring Boot使用H2内存数据库 在之前的文章中我们有提到在Spring Boot中使用H2内存数据库方便开发和测试.本文我 ...
- Libra教程之:来了,你最爱的Move语言
文章目录 Move语言 Move的核心概念 Move交易脚本 Move modules Move resources 写一个Move程序 编写交易脚本 编写自己的Modules Move语言 Move ...
- 用libevent写的海康摄像头rtsp客户端
之前一直使用live555作为RTSP的客户端,但其框架臃肿,虽然支持各种格式,但实际中并没有这些需求,关键是其注重于格式的解析,却不注重网络IO,单线程下性能也不高,重新用libevent编写rts ...
- Linux硬盘分区知识
前言 硬盘使用前,一般要分区,格式化(创建文件系统)<== 存放数据 类比,房子使用前,一般要隔断,装修,买家具,再住人. 分区 一块硬盘: 主分区.扩展分区.逻辑分区 主分区+扩展分区的数量& ...
- Waiting for another flutter command to release the startup lock...
2019独角兽企业重金招聘Python工程师标准>>> rm ./flutter/bin/cache/lockfile info from 转载于:https://my.oschin ...
- 有赞透明多级缓存解决方案(TMC)设计思路
引子 TMC 是什么 TMC,即"透明多级缓存(Transparent Multilevel Cache)",是有赞 PaaS 团队给公司内应用提供的整体缓存解决方案. TMC 在 ...
- 小老板,我学的计算机组成原理告诉我半导体存储器都是断电后丢失的,为什么U盘SSD(固态硬盘)没事呢?
什么是闪存: 快闪存储器(英语:flash memory),是一种电子式可清除程序化只读存储器的形式,允许在操作中被多次擦或写的存储器 存储原理 要讲解闪存的存储原理,还是要从EPROM和EEPROM ...
- Codeforce-CodeCraft-20 (Div. 2)-B. String Modification (找规律+模拟)
Vasya has a string s of length n. He decides to make the following modification to the string: Pick ...