当前位置: 首页 > news >正文

宝塔面板部署前后端项目SpringBoot+Vue2

这篇博客主要用来记录宝塔部署前端后端项目的过程。因为宝塔部署有点麻烦,至少在我看来挺麻烦的。我还是喜欢原始的ssh连接服务器进行操作。但是公司有项目用到了宝塔,没办法啊,只能摸索记录一下。

我们需要提前准备好后端项目的jar包和前端项目的dist文件哈!

文章目录

    • 前端项目的部署
    • 后端项目的部署
    • nginx反向代理的配置

前端项目的部署

先去文件里创建好项目文件,然后进去直接上传dist文件

在这里插入图片描述

在这里插入图片描述

把前端项目上传上去,然后解压:

在这里插入图片描述

接下来去创建网站、站点:

在这里插入图片描述

在这里插入图片描述

可以看到网站创建好了:

在这里插入图片描述

记住,这里目录要放到dist:

在这里插入图片描述在这里插入图片描述

后端项目的部署

再部署后端项目之前,需要准备好jar包

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

nginx反向代理的配置

反向代理配置在前端配置。

在这里插入图片描述

在这里插入图片描述

     # 前端配置location / {root /www/wwwroot/demo.html.test.jiekee.com/dist;  # 前端打包文件存放路径index index.html;try_files $uri $uri/ /index.html;  # 支持 vue-router 的 history 模式}# 后端接口代理location /api/ {proxy_pass http://localhost:37018/api/;  # 后端服务地址proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header X-Forwarded-Proto $scheme;}

注:

工作流程:

  1. 前端发送请求到 /api/image/analyze
  2. Nginx 匹配到 location /api/
  3. 请求被转发到 http://127.0.0.1:37018/api/image/analyze
    如果我们不加 /api ,比如:
location /api/ {proxy_pass http://127.0.0.1:37018/;
}

那么请求会变成 http://127.0.0.1:37018/image/analyze ,这样就找不到后端的接口了,因为我们的后端 Controller 都是以 /api 开头的。

在这里插入图片描述

在这个项目中,Nginx 主要发挥了"中间层"的作用,具体表现在:

  1. 请求转发:

    • 当前端发送 /api/image/analyze 请求时
    • Nginx 接收到请求后,将其转发到后端服务(37018端口)
    • 这就是为什么前端代码中可以直接使用:
axios.post('/api/image/analyze', {base64Image: base64Image,textContent: this.analysisPrompt
})

如果不使用 Nginx,你需要: 1. 前端直接访问后端 IP:端口(例如 http://47.120.52.207:37018/api/…) 2. 处理跨域问题 3. 单独部署静态资源 所以 Nginx 在这里起到了统一入口、请求转发和资源管理的作用。不这样做,前端代码里就要写死各种端口了,这样做肯定不行的!

相关文章:

  • 【C语言】字符串函数及其部分模拟实现
  • 【数据结构】2-3-4 单链表的建立
  • 实现菜谱二级联动导航
  • java每日精进 5.18【文件存储】
  • 张 心理问题的分类以及解决流程
  • Django 项目创建全攻略
  • NE555双音门铃实验
  • Docker配置SRS服务器 ,ffmpeg使用rtmp协议推流+vlc拉流
  • 彻底解决docker代理配置与无法拉取镜像问题
  • Limesurvay系统“48核心92GB服务器”优化方案
  • C++11-(2)
  • 使用conda创建python虚拟环境,并自定义路径
  • 优化 Spring Boot 应用启动性能的实践指南
  • 互联网大厂Java面试:技术栈与业务场景深度解析
  • lvs-dr部署
  • 京东商品详情API接口开发指南(含Java/Python实现)
  • spark数据的提取和保存
  • MCP实战:在扣子空间用扣子工作流MCP,一句话生成儿童故事rap视频
  • Java虚拟机 - JVM与Java体系结构
  • 代码审计-php框架开发,实战tp项目,打击微交易,源码获取,扩大战果
  • “大国重器”、新型反隐身雷达……世界雷达展全面展示尖端装备
  • 推开“房间”的门:一部“生命存在的舞台” 史
  • 101岁陕西省军区原司令员冀廷璧逝世,曾参加百团大战
  • 泽连斯基:俄代表团级别低,没人能做决定
  • 韶关一企业将消防安装工程肢解发包,广东住建厅:罚款逾五万
  • 中国证券业协会修订发布《证券纠纷调解规则》