通过宝塔面板部署一个SpringBoot+Vue前后端分离项目的指南

在这个解决方案中,我们将使用宝塔面板来部署一个SpringBoot后端和Vue前端分离的项目。以下是部署的步骤:

  1. 安装宝塔面板:

    • 在服务器上安装宝塔面板。
  2. 配置服务器环境:

    • 在宝塔面板中安装Java环境(例如OpenJDK)。
    • 安装Maven,用于构建SpringBoot项目。
    • 安装Nginx,用于部署Vue前端。
  3. 构建SpringBoot项目:

    • 在本地开发环境中,将SpringBoot项目构建成jar包。
    • 使用宝塔的文件传输功能,将jar包上传到服务器。
  4. 创建Systemd服务:

    • 创建一个Systemd服务文件来管理SpringBoot应用。
  5. 部署Vue前端:

    • 在本地构建Vue项目。
    • 将构建好的静态文件通过宝塔的文件管理功能上传到Nginx的网站目录。
  6. 配置Nginx反向代理:

    • 设置Nginx来代理API请求到SpringBoot应用。
  7. 设置安全规则:

    • 在宝塔面板中设置防火墙规则,仅允许必要的端口(如SSH、HTTP/HTTPS)对外开放。
  8. 启动服务并测试:

    • 启动SpringBoot应用。
    • 通过浏览器测试前后端分离项目的功能。

以下是可能的示例代码和配置:




# 安装Java环境
yum install java-1.8.0-openjdk
 
# 安装Maven
yum install maven
 
# 安装Nginx
yum install nginx
 
# 创建Systemd服务文件 /etc/systemd/system/your-app.service
[Unit]
Description=Your SpringBoot Application
After=network.target
 
[Service]
Type=simple
User=root
ExecStart=/path/to/your/java/bin/java -jar /path/to/your/app.jar
Restart=on-failure
 
[Install]
WantedBy=multi-user.target
 
# 启用并启动服务
systemctl daemon-reload
systemctl enable your-app
systemctl start your-app
 
# Nginx配置反向代理
server {
    listen 80;
    server_name your-domain.com;
 
    location / {
        root /path/to/your/vue/dist;
        try_files $uri $uri/ /index.html;
    }
 
    location /api/ {
        proxy_pass http://127.0.0.1:8080; # SpringBoot应用的端口
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

这个解决方案提供了部署SpringBoot和Vue前端分离项目的高级指南,并给出了相关的示例代码。在实际部署时,需要根据项目具体情况进行调整。

最后修改于:2024年08月15日 17:48

评论已关闭

推荐阅读

Vue中使用mind-map实现在线思维导图
2024年08月04日
VUE
Web前端最全Vue实现免密登录跳转的方式_vue怎么样不登录返回首页,最强技术实现
2024年08月04日
VUE
vue3 项目搭建教程(基于create-vue,vite,Vite + Vue)
2024年08月04日
VUE
Vue-颜色选择器实现方案——>Vue-Color( 实战*1+ Demo*7)
2024年08月04日
VUE
Vue项目卡顿慢加载?这些优化技巧告诉你!_vue数据多渲染卡顿
2024年08月04日
VUE
vue中的keep-alive详解与应用场景
2024年08月04日
VUE
Vue、React实现excel导出功能(三种实现方式保姆级讲解)
2024年08月04日
vue-office/docx插件实现docx文件预览
2024年08月04日
VUE
java调用js文件的两种方法(支持V8引擎)
2024年08月04日
JavaScript:解决计算精度问题/mathjs/bignumber.js/big.js/decimal.js
2024年08月04日
两周从爬虫小白变大神 _yjs_js_security_passport
2024年08月04日
JS笔记(对象、函数、数组)
2024年08月04日
Markdown.js:强大的纯JavaScript Markdown解析器
2024年08月04日
Vue项目:js模拟点击a标签下载文件并重命名,URL文件地址下载方法、请求接口下载文件方法总结。
2024年08月04日
vue 父组件怎么获取子组件里面的data数据
2024年08月04日
VUE
个人开发实现AI套壳网站快速搭建(Vue+elementUI+SpringBoot)
2024年08月04日
el-table 表格封装并改造实现单元格可编辑
2024年08月04日
none
nodejs环境下创建vue项目、SSH密钥登陆!!!
2024年08月04日
vue+quill+element-ui实现视频、图片上传及缩放保姆级教程,轻松使用富文本
2024年08月04日
【three.js】22. Imported Models导入模型
2024年08月04日