前后端分离架构(Vue 前端 + Java/SpringBoot 后端)项目部署 || 全服务器部署(宝塔面板)全流程 || 前端Netlify + 后端服务器 部署对比

前后端分离架构(Vue 前端 + Java/SpringBoot 后端)项目部署 || 全服务器部署(宝塔面板)全流程 || 前端Netlify + 后端服务器 部署对比

一、 部署需要分「前端」「后端」「数据库」三个部分

优先选低成本 + 易操作的组合:

  • 前端:免费静态托管平台(Netlify/Vercel,无需服务器)
  • 后端:云服务器(学生机,每月 9 元起)
  • 数据库:云服务器内置 MySQL(或用免费云数据库)
下文的部署采用的是全服务器部署方式,即前后端都部署到云服务器上

二、第一步:部署前端(Vue 项目,免费 + 5 分钟完成)

  1. 本地打包前端代码
    在 Vue 项目根目录执行命令,生成静态文件目录dist:
npm run build 
  1. 部署到 Netlify(免费、自动构建、带 HTTPS)
    (如果是全服务器部署,此步骤可以跳过)
    把前端代码推到 GitHub/Gitee 仓库(已有仓库可跳过);
    打开Netlify 官网,用 GitHub/Gitee 账号登录;
    点击「Add new site」→「Import an existing project」,选择你的前端仓库;
    配置构建参数(Netlify 会自动识别 Vue 项目,默认即可):
    构建命令:npm run build
    发布目录:dist
    点击「Deploy site」,等待 2 分钟,Netlify 会生成一个免费域名(如your-site.netlify.app),前端部署完成。

三、第二步:部署后端(Java/SpringBoot,学生机低成本)

  1. 购买学生云服务器
    推荐腾讯云轻量应用服务器(学生机):
    价格:2 核 2G/1M 带宽,每月 9 元(需学生认证);
    系统:选CentOS 7.x(Linux 系统,稳定常用,宝塔面板部署)。
  2. 服务器环境配置(用宝塔面板可视化操作)
    登录腾讯云服务器控制台,通过「WebShell」登录服务器;
    安装宝塔面板(可视化管理服务器):
wget -O install.sh http://download.bt.cn/install/install_6.0.sh &&bash install.sh 

这个命令只需要输入一次,记住给的账号和密码,下次再次登录,直接使用外网地址就行,重复运行会导致内存挤压,程序崩溃

登录宝塔面板


安装完成后,记录宝塔的登录地址(如http://服务器IP:8888)、账号密码;
登录宝塔面板,一键安装「LNMP 套件」(包含 Nginx/MySQL/Node.js)。

⚠ 如果忘记宝塔界面登录密码,重置方法:
cmd + R打开终端面板,输入 ssr 用户名@主机服务器ip指定 SSR 客户端连接代理服务器

接着输入下面的代码

cd /www/server/panel && btpython tools.py panel 你的重置密码 
宝塔面板密码重置


当看见命令行返回了你宝塔账户的用户名,就证明你成功地重置了密码。
完成以上操作就可以重新登录宝塔面板啦!

四、第三步:部署数据库(MySQL,服务器内置)

宝塔面板→「软件商店」→安装MySQL 8.0;
点击「设置」→「数据库」→「添加数据库」:
数据库名:quiz_db
用户名 / 密码:自定义(如quiz_user/123456);
导入本地数据库脚本:
本地导出 SQL 文件,在宝塔「数据库」→「导入」上传 SQL 文件。

如果出现报错信息:mysqldump: [ERROR] unknown variable ‘collation=utf8mb4_general_ci’.
数据库部署报错信息


✅ 本地 DataGrip 连接的是 MySQL 8.0 版本,导出的 SQL 里自带了高版本专属的排序规则 utf8mb4_0900_ai_ci;✅ 服务器宝塔的 MySQL 版本是 5.7/5.6 版本,不认识这个高版本规则,直接拒绝导入,同时连带报表不存在(因为建表语句第一步就执行失败了)。

五、第四步:连接前后端 + 配置域名

  1. 后端配置数据库
    修改 SpringBoot 项目的application.yml,将数据库连接改为服务器的 MySQL:
spring:datasource:url: jdbc:mysql://服务器IP:3306/quiz_db?useSSL=false&serverTimezone=Asia/Shanghaiusername: quiz_user password:123456

打包 jar 包,上传到服务器并启动后端服务。
部署后端代码具体步骤:

  1. 本地打包 SpringBoot 项目为jar包: IDEA 中执行mvn package,生成target/xxx.jar;
  2. 上传jar 包到服务器: 宝塔面板→「文件」→新建目录(如/www/backend),上传 jar 包;
  3. 启动后端服务:
    • 安装「PM2
      管理器」、「Java项目项目管理器」(宝塔软件商店);
    • 点击左侧导航栏「网站」→「Java项目」: 项目名称:自定义(如quiz-backend)
      • 启动文件:选择上传的 jar 包 启动命令:java -jar xxx.jar --server.port=8080(指定端口);

使用Nginx进行反向代理
「网站」→「PHP项目」→ 「添加站点」

Nginx创建节点


项目前端dist文件结构

前端打包成静态资源放在和jar同一目录下

项目结构

完成创建后项目会自动启动,后端服务在服务器8080端口运行。

项目后端部署

六、最终访问

公网访问链接


将这个网址发给你的朋友,他们就可以访问你的网站啦!

以上采用的是全服务器部署策略,若是采用前端Netlify部署 + 后端服务器部署,Netlify会强制将http请求转换成https请求,而https请求若是没有部署ssl证书和域名的加持,浏览器会识别成不安全网站,向后端请求资源的行为会被拦截

解决方案有两个:

方案一:全服务器部署 ,使用http请求(即上文提到的部署方式)

  • 将前后端都部署在云服务器上,使用http请求和默认80端口,将前端项目打包,上传至后端项目
    所在文件夹,使用Nginx进行反向代理
  • 核心优势是 “零额外成本”(无需买域名、SSL 证书),适合个人测试、小型 demo 或非公开项目;
  • 缺点: “HTTP” 有安全性缺陷(数据传输未加密,适合非敏感场景),且无法使用需要 HTTPS 的功能(如浏览器定位、PWA、部分第三方 API); 前端静态资源和后端 API 都依赖同一台服务器的带宽和性能,若访问量增大,可能需要升级服务器配置;
  • Nginx 的作用:监听服务器的 80 端口(HTTP 默认端口),当用户访问http://服务器IP时,Nginx 会 “转发请求”—— 静态资源(页面、CSS、JS)直接返回前端文件,API 请求(如/api/login)转发到后端的 8080 端口

请求发送流程图:

1. 在浏览器输入:http://服务器IP2. 80端口请求进入Nginx3. 判断请求类型:静态资源(页面/CSS/JS)3. 判断请求类型:API接口(如/api/login)4. 返回静态资源4. 处理API请求,返回数据(如JSON)5. Nginx将结果返回给浏览器6. 浏览器渲染页面,展示内容

用户

云服务器(公网IP)

Nginx反向代理

服务器本地:前端静态文件(dist文件夹)

服务器本地:后端服务(8080端口)

用户看到最终页面

方案二:Netlify 前端 + 服务器后端 , 使用https请求

  • 核心优势是 “生产级正式性”(HTTPS 加密、自定义域名),适合公开项目、面向用户的产品,但需承担域名 / SSL 成本(部分 SSL 免费),并遵守备案规则;前端静态资源由 Netlify 的 CDN(全球分发网络)加载,用户访问页面更快(就近获取资源),后端仅需处理 API 请求,服务器压力更小,更适合有一定访问量的项目。
  • 后端服务器配置 SSL 证书(通过 Nginx 或后端框架本身),让后端接口支持https://你的域名:8080/api(或用 Nginx 监听 443 端口,转发到 8080,隐藏端口)—— 否则前端(HTTPS)调用后端(HTTP)仍会被浏览器拦截(混合内容错误)。

如果坚持将前端部署在Netlify上,需要购买域名,申请SSL证书,购买域名后,需要解析域名(DNS[ Domain Name System]解析),与自己的服务器进行绑定,但是,这个方法,如果是在腾讯云购买域名,会提示你,只有备案过的域名才能进行解析,但是,只有购买期超过三个月的域名才能够备案

申请ssl证书失败

请求发送流程图:

1. 输入: https://你的自定义域名2. 加载前端静态资源3. 返回前端页面 完成初步渲染4. 前端发起接口请求: https://你的域名/api5. 解析域名 → 云服务器公网IP6. 转发请求到本机后端7. 处理业务 返回JSON数据8. HTTPS加密返回数据9. 把接口数据返回前端

用户浏览器

Netlify CDN服务器

Netlify 存储前端打包文件

DNS域名解析服务器

云服务器 443端口 HTTPS

Nginx 反向代理 已配置SSL证书

云服务器本地 后端服务 8080端口

浏览器渲染接口数据 展示最终完整页面

简言之,方案一更加省钱,但是,方案二是更为正式稳健的一种部署方案。

Read more

【无人机源码】低空无人机智能管控、AI 无人机智慧巡检平台,20+AI场景智能识别,赋能低空一网通飞新

【无人机源码】低空无人机智能管控、AI 无人机智慧巡检平台,20+AI场景智能识别,赋能低空一网通飞新

# 空域数智通:县域低空一体化AI巡检平台 ## 源码交付|1+1+X空地一体架构|60+智能算法|县域低空经济落地解决方案 🛰️卫星:BNBJKJK --- ### 平台核心定位:打通低空经济“最后一公里” 在国家-省-市三级低空监管体系下,县域平台承担着**关键落地执行单元**的角色。我们专注于解决县域低空管理“看得见、管得住、用得好”的实践难题,将顶层设计转化为基层可执行、可运营的数字化能力。 --- ### 双核驱动:数字基座+数据智能 **数字孪生基座** - 真实映射县域“场、站、机”等物理设施 - 集成“通、导、监”等数字基础设施 - 构建全域可视、可管、可控的数字空间 **数据智能中枢** - 汇聚空域、

Stable Diffusion显存管理革命:彻底解决内存爆满问题

还在为Stable Diffusion显存不足而烦恼吗?每次生成图像都像在玩随机挑战,不知道什么时候就会弹出内存错误?别担心,这款专为Automatic1111 WebUI设计的显存释放扩展将彻底改变你的创作体验。 【免费下载链接】sd-webui-memory-releaseAn Extension for Automatic1111 Webui that releases the memory each generation 项目地址: https://gitcode.com/gh_mirrors/sd/sd-webui-memory-release 🎯 为什么你的显卡总是"闹脾气"? 显存问题的三大症状诊断: 💡 生成后显存不释放:完成一次生成后,内存占用依然居高不下 💡 连续操作速度变慢:批量生成时越到后面速度越慢 💡 多任务运行就崩溃:同时开浏览器或其他应用直接报错 新手必看:显存管理基础认知 * 模型加载需要占用大量显存空间 * 每次生成都会产生临时缓存数据 * 显存回收不及时会导致累积效应 🚀 快速上手:三步安装配置指南 第一步:获取扩

从零开发 AR 演讲提词器:基于 Rokid CXR-M SDK 的实战指南

从零开发 AR 演讲提词器:基于 Rokid CXR-M SDK 的实战指南

从零开发 AR 演讲提词器:基于 Rokid CXR-M SDK 的实战指南 站在讲台上,数百双眼睛注视着你。你开始演讲,却发现关键时刻想不起下一句要说什么——这种场景,每个演讲者都不陌生。 传统的解决方案是在讲台上放一张稿子,或者用 PPT 做备注。但低头看稿显得不专业,看 PPT 又要扭头,容易打断演讲节奏。如果能有一个只有自己能看到的"隐形提词器",演讲就能更加从容自信。 Rokid AR 眼镜恰好提供了这种可能:将提词内容无线传输到眼镜显示屏,演讲者只需自然平视,文字便清晰呈现,而台下观众毫无察觉。本文将完整记录如何利用 Rokid CXR-M SDK 从零开发这款演讲提词器应用。 一、技术方案设计 1.1 为什么选择 AR 眼镜 在确定技术方案前,我们先对比几种提词方案: 方案

无人机数据集汇总无人机航拍各个方面检测分割数据集合集

本数据集集合了面向无人机视觉任务的大规模、多场景、多目标标注数据资源,涵盖了地理环境、智慧城市、基础设施巡检、农业生产、公共安全与灾害监测等多个关键领域。数据主要以两种主流格式提供:适用于目标检测的VOC/YOLO格式与适用于像素级语义分割的LabelMe格式,为算法开发与模型训练提供了高度结构化的标注支持。 在地理与农业监测方面,包含田地、道路、森林、水体等地理要素的分割数据集,以及作物病害、杂草识别、农田农机、牛羊牲畜等农业目标的检测数据,支持精准农业与生态研究。智慧城市与交通领域提供了丰富的城市街道场景数据,涵盖行人、车辆、交通标志、占道经营、消防通道、广告牌等目标的检测与分割,助力城市智能化管理。基础设施巡检是另一重点,覆盖电力线、光伏板、桥梁、铁路、风力发电机等设备的缺陷与异常检测,以及工地车辆、施工人员、物料垃圾的识别,满足工业自动化巡检需求。在灾害与安全监控中,包含滑坡、洪水、火灾烟雾、河道垃圾、违规建筑等应急场景的检测与分割数据,同时提供了溺水人员、海上救援、军事目标等特殊任务的专项数据集。此外,