前后端分离架构(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

ARM Linux 驱动开发篇---Linux 设备树简介-- Ubuntu20.04

ARM Linux 驱动开发篇---Linux 设备树简介-- Ubuntu20.04

🎬 渡水无言:个人主页渡水无言 ❄专栏传送门: 《linux专栏》   《嵌入式linux驱动开发》 ⭐️流水不争先,争的是滔滔不绝  📚博主简介:第二十届中国研究生电子设计竞赛全国二等奖 |国家奖学金 | 省级三好学生 | 省级优秀毕业生获得者 | ZEEKLOG新星杯TOP18 | 半导纵横专栏博主 | 211在读研究生 在这里主要分享自己学习的linux嵌入式领域知识;有分享错误或者不足的地方欢迎大佬指导,也欢迎各位大佬互相三连 目录 前言 一、什么是设备树? 二、DTS、DTB 和 DTC 三、DTS编译规则 四、DTB 文件最终如何被内核使用? 总结 前言 在传统驱动中,GPIO址、中断号、时钟参数等硬件信息都硬编码在代码里,换一块开发板就要改一次驱动;而设备树通过.dts文件统一描述所有硬件资源,驱动只需通过标准 API获取资源,实现 “一次编写、多板适配”。如今设备树已经成为 Linux 驱动开发的核心规范,是每一位嵌入式

By Ne0inhk
【记录】Tailscale|部署 Tailscale 到 linux 主机或 Docker 上

【记录】Tailscale|部署 Tailscale 到 linux 主机或 Docker 上

文章目录 * 🐧 Linux 与 Docker 环境下 Tailscale 异地组网全攻略:从宿主机到容器内的极致部署 * 一、 为什么选择 Tailscale? * 二、 场景一:Linux 宿主机直接部署 * 1. 一键安装 * 2. 启动与认证 * 3. 进阶参数(可选) * 三、 场景二:Docker 容器内由零构建(进阶技巧) * 📋 准备工作 * 🚀 步骤详解 * 第一阶段:环境构建与后台启动 * 🔐 认证步骤(需要在浏览器中操作) * 第二阶段:验证与收尾 * ⚠️ 注意事项 * 四、 常用维护命令速查 🐧 Linux 与 Docker 环境下 Tailscale 异地组网全攻略:从宿主机到容器内的极致部署 在当今的云原生和远程办公时代,异地组网和内网穿透是开发者绕不开的话题。相比于传统的 OpenVPN 或

By Ne0inhk

警惕!OpenClaw隐藏的致命Bug:网络超时误报上下文溢出,可导致系统陷入死循环

救命!我的AI助手OpenClaw深夜疯了!前天晚上开始,如果按照推文时间来算,应该是前天晚上了,OpenClaw像着了魔一样,过一会就在聊天窗口刷屏报错,最后竟然把自己给玩死了! 我们前面介绍了两种方式来给OpenClaw提供近乎无限量的token,一种是对接有免费额度的平台(OpenClaw(原ClawdBot)免费AI模型终极配置指南:精选20+精英模型,打造你的低成本AI军团),另一种是直接“强奸”Antigravity(还在为AI API费用发愁?我找到了免费使用Gemini 3和Claude 4.5的方法)。 我本以为有这么高端的模型,再加上多档回退机制,我本该高枕无忧了,结果是万万没想到,我的OpenClaw遭遇了一场由底层Bug引发的鬼打墙式死循环! 昨天晚上七点半开始,间隔一段时间他就开始自己报错,到今天凌晨不报了,我以为恢复了,结果他又开始报上了! 我分析了一下规律,发现OpenClaw机器人刷屏报错的时间间隔大约是固定的75分钟,报错内容是Context overflow(上下文溢出)、prompt too large(提示词太大)或Agent faile

By Ne0inhk
基于腾讯云MCP广场的AI自动化实践:爬取小红书热门话题

基于腾讯云MCP广场的AI自动化实践:爬取小红书热门话题

基于腾讯云MCP广场的AI自动化实践:爬取小红书热门话题 我正在参加Trae「超级体验官」创意实践征文,本文所使用的 Trae 免费下载链接:www.trae.com.cn/?utm_source… 🔎 背景 在人工智能快速发展的时代,AI技术不仅重塑了传统行业,也极大提高了开发者的工作效率。腾讯云推出的 MCP(Model Context Protocol),作为一种创新的技术协议,能够帮助开发者将云能力、AI模型与自动化流程高效整合,让开发者可以将更多精力集中在业务逻辑和创新上,而不再是重复性工作。 最近,腾讯云推出了**MCP广场,一个帮助开发者轻松创建与管理自动化应用的平台。在探索过程中,我发现了一个非常有趣的工具——超浏览器AI自动化**,它能让开发者通过浏览器模拟技术实现自动化操作。我曾经看到过一个小红书爬取的代码,但由于种种原因没有成功运行。于是,我决定尝试利用超浏览器AI自动化功能,结合腾讯云MCP的能力,进行小红书热门话题的自动化爬取与分析,最终成功实现了这一目标。 📉效果展示 通过本次实践,成功构建了一个自动化流程,它能够: 1. 将提取到的

By Ne0inhk