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

Windows Server部署Vue3+Spring Boot项目

在Windows Server 上部署Vue3 + Spring Boot前后端分离项目的详细步骤如下:


一、环境准备

  1. 安装JDK 17+

    • 下载JDK MSI安装包(如Oracle JDK 或 OpenJDK)

    • 双击安装,配置环境变量:

      • JAVA_HOME:JDK安装路径(如 C:\Program Files\Java\jdk-17

      • 添加 %JAVA_HOME%\bin 到 Path

  2. 安装Node.js

    • 下载Node.js LTS版

    • 默认安装,验证安装成功:

      bash

      复制

      下载

      node -v
      npm -v
  3. 安装Nginx

    • 下载Windows版Nginx

    • 解压到目录(如 C:\nginx


二、后端部署(Spring Boot)

  1. 打包项目

    bash

    复制

    下载

    # 在Spring Boot项目根目录执行
    mvn clean package -DskipTests
    • 生成 target/项目名.jar(如 myapp-0.0.1-SNAPSHOT.jar

  2. 上传文件到服务器

    • 将JAR包放到服务器目录(如 C:\app\backend

  3. 启动Spring Boot

    bash

    复制

    下载

    java -jar C:\app\backend\myapp-0.0.1-SNAPSHOT.jar
    • 后台运行(推荐使用批处理):

      batch

      复制

      下载

      @echo off
      start javaw -jar C:\app\backend\myapp-0.0.1-SNAPSHOT.jar
      exit

      保存为 run-backend.bat 并双击运行。

  4. 验证后端

    • 访问 http://localhost:8080/api/test(按实际API路径)


三、前端部署(Vue3)

  1. 打包项目

    bash

    复制

    下载

    npm run build
    • 生成 dist 文件夹(包含静态文件)

  2. 上传文件到服务器

    • 将 dist 文件夹内容放到Nginx目录(如 C:\nginx\html\frontend

  3. 配置Nginx反向代理

    • 编辑 C:\nginx\conf\nginx.conf

      nginx

      复制

      下载

      server {listen       80;server_name  your-domain.com; # 替换为域名或IP# 前端静态资源location / {root   html/frontend;index  index.html;try_files $uri $uri/ /index.html; # 支持Vue Router history模式}# 后端API代理location /api {proxy_pass http://localhost:8080;proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;}
      }
  4. 启动Nginx

    bash

    复制

    下载

    # 命令行进入nginx目录
    start nginx

四、防火墙配置

  1. 开放端口(管理员PowerShell):

    powershell

    复制

    下载

    New-NetFirewallRule -DisplayName "Allow HTTP" -Direction Inbound -Protocol TCP -LocalPort 80 -Action Allow
    New-NetFirewallRule -DisplayName "Allow Spring Boot" -Direction Inbound -Protocol TCP -LocalPort 8080 -Action Allow

五、设置开机自启动

  1. Spring Boot

    • 创建批处理文件 start-backend.bat(内容同上)

    • 将快捷方式放入启动文件夹:

      复制

      下载

      C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp
  2. Nginx

    • 创建批处理文件 start-nginx.bat

      batch

      复制

      下载

      @echo off
      C:\nginx\nginx.exe
    • 同样将快捷方式放入启动文件夹。


六、验证部署

  1. 访问前端页面:

    复制

    下载

    http://服务器IP或域名/
  2. 检查API请求:

    • 前端页面调用 /api/xxx 应正常返回后端数据


常见问题解决

  1. 端口冲突

    • 修改Spring Boot端口:application.properties 中添加 server.port=9090

    • 或关闭占用端口的进程(如IIS默认占用80端口):

      bash

      复制

      下载

      net stop http /y
  2. Nginx代理404

    • 确保 proxy_pass 地址与Spring Boot运行地址一致

    • 检查后端API路径前缀(如 /api/v1 需在Nginx中匹配)

  3. 静态资源加载失败

    • 检查Nginx root 路径是否正确

    • Vue打包时设置公共路径(vue.config.js):

      js

      复制

      下载

      module.exports = {publicPath: process.env.NODE_ENV === 'production' ? '/frontend/' : '/'
      }

关键提示

  • 生产环境建议使用 PM2 管理Node进程(但Vue是静态资源无需Node运行时)

  • 数据库等依赖服务需独立部署并配置连接信息

  • 使用HTTPS可配置Nginx SSL证书(Let's Encrypt)

通过以上步骤,即可完成全栈项目在Windows Server 的部署。

在同一台Windows Server 服务器上完全可以同时运行多个JAR包。这是企业级部署的常见场景(如微服务架构)。以下是具体实现方法和注意事项:


✅ 关键实现步骤

1. 端口分配

为每个JAR分配不同端口(避免冲突):

  • 修改Spring Boot的 application.properties

    properties

    复制

    下载

    # 应用1
    server.port=8080
    # 应用2
    server.port=8081
  • 或启动时指定端口:

    bash

    复制

    下载

    java -jar app1.jar --server.port=8080
    java -jar app2.jar --server.port=8081
2. 独立目录部署

为每个应用创建独立目录:

复制

下载

C:\apps
├─app1
│   ├─app1.jar
│   └─config/  # 配置文件
├─app2
│   ├─app2.jar
│   └─config/
3. 批处理脚本启动

创建多个启动脚本(如 start-app1.batstart-app2.bat):

batch

复制

下载

:: start-app1.bat
@echo off
cd /d C:\apps\app1
start javaw -Xmx512m -jar app1.jar --spring.config.location=config/application.properties
exit

关键参数

  • javaw:无控制台窗口的后台运行

  • -Xmx512m:限制内存用量

  • --spring.config.location:指定配置文件路径

4. Nginx反向代理配置

统一入口转发到不同应用:

nginx

复制

下载

server {listen 80;# 应用1代理location /app1 {proxy_pass http://localhost:8080;proxy_set_header Host $host;}# 应用2代理location /app2 {proxy_pass http://localhost:8081;proxy_set_header Host $host;}
}

⚠️ 注意事项

1. 资源监控
  • 检查服务器资源占用:

    powershell

    复制

    下载

    # 查看内存/CPU使用
    Get-Process javaw | Format-Table Name, CPU, WorkingSet
  • 建议配置JVM内存限制(避免OOM):

    bash

    复制

    下载

    java -Xms256m -Xmx1024m -jar app.jar
2. 进程管理
  • 查看所有Java进程

    bash

    复制

    下载

    tasklist | findstr "javaw"
  • 停止特定应用

    bash

    复制

    下载

    taskkill /PID <进程ID> /F
3. 日志分离

为每个应用配置独立日志文件:

properties

复制

下载

# application.properties
logging.file.name=logs/app1.log
4. 服务化部署(推荐)

使用 NSSM 将每个JAR注册为Windows服务:

  1. 下载 nssm.exe

  2. 创建服务:

    powershell

    复制

    下载

    # 注册应用1服务
    nssm install App1_Service "C:\Program Files\Java\jdk-17\bin\java.exe"
    nssm set App1_Service AppParameters "-jar C:\apps\app1\app1.jar"
    nssm set App1_Service AppDirectory "C:\apps\app1"# 启动服务
    nssm start App1_Service
    • 服务管理:services.msc


📊 资源分配建议

应用规模JVM堆内存建议最大并发应用数
小型应用512MB4~6个
中型应用1-2GB2~3个
大型应用4GB+1个(独占服务器)

经验值:预留至少1GB内存给操作系统和Nginx


🔧 故障排查技巧

  1. 端口冲突

    powershell

    复制

    下载

    netstat -ano | findstr ":8080"
  2. 查看特定应用日志

    bash

    复制

    下载

    tail -f C:\apps\app1\logs\application.log
  3. 内存泄漏检测

    bash

    复制

    下载

    jcmd <PID> GC.heap_info

通过以上方案,您可以稳定运行多个Spring Boot应用。对于生产环境,建议:

  1. 使用 Docker容器化部署(需Windows Server 2016+)

  2. 配置 APM监控(如SkyWalking)

  3. 重要服务配置 集群高可用

http://www.lqws.cn/news/96391.html

相关文章:

  • 虚拟现实教育终端技术方案——基于EFISH-SCB-RK3588的全场景国产化替代
  • 连接关键点:使用 ES|QL 联接实现更丰富的可观测性洞察
  • VR教育:开启教育新时代的钥匙
  • OpenCV 滑动条调整图像对比度和亮度
  • OpenCV CUDA模块特征检测------创建Harris角点检测器的GPU实现接口cv::cuda::createHarrisCorner
  • 【运维】统信UOS操作系统aarch64自制OpenSSH 9.6p1 rpm包(含ssh-copy-id命令)修复漏洞
  • 基于 COM 的 XML 解析技术(MSXML) 的总结
  • mac下通过anaconda安装Python
  • c语言内存函数
  • Java 中执行命令并使用指定配置文件的最佳实践
  • Oracle双平面适用场景讨论会议
  • 云服务器宕机或重启后数据会丢失吗?
  • 数据驱动在线教育平台优化:用数据帮你变成“教书匠+数据控”
  • Agentic Workflow是什么?Agentic Workflow会成为下一个AI风口吗?
  • Springboot中Controller接收参数的方式
  • 第7章 :面向对象
  • Spring Security
  • tryhackme——Abusing Windows Internals(进程注入)
  • Qwen3高效微调
  • 服务器被攻击了怎么办
  • 机器学习与深度学习08-随机森林02
  • 解决MyBatis参数绑定中参数名不一致导致的错误问题
  • 服务器租用:高防CDN和加速CDN的区别
  • Java基础之数组(附带Comparator)
  • 《TCP/IP 详解 卷1:协议》第5章:Internet协议
  • electron-vite_18桌面共享
  • 电脑硬盘分几个区好
  • Oracle、PostgreSQL 与 MySQL 数据库对比分析与实践指南
  • React知识点梳理
  • pip安装python第三方库报错