简打卡
51.76M · 2026-03-28
本页面详细介绍了 VTJ.PRO 平台的生产部署策略,包括运行 Vue 3 前端和 NestJS 后端所需的基础设施配置、使用 PM2 进行进程管理,以及用于生成分发版本的自动化打包脚本。
VTJ.PRO 采用标准的全栈部署模型,其中反向代理(Nginx)负责处理 SSL 终止和静态资源服务,而进程管理器(PM2)确保 Node.js 后端持续运行。
Nginx 配置主要承担三个角色:
frontend/dist 目录提供编译后的前端文件。/api/ 请求转发至 NestJS 后端(默认端口 3000)。try_files 支持不同运行时(Web、H5、UniApp)的客户端路由。下图展示了 Nginx 如何根据 URL 路径路由传入流量:
Nginx 请求分发器
关键配置参数:
/home/vtj-pro/frontend/dist10M 以适应大型 DSL 或文件上传X-Real-IP 和 X-Forwarded-For 以确保后端能识别客户端 IP/home/app.vtj.pro_nginx/NestJS 后端使用 PM2 进行管理,以实现高可用性、故障自动重启和日志管理。
虽然代码库中没有专用的 ecosystem.config.js,但标准部署涉及运行编译后的主入口文件:
# 示例部署命令
pm2 start backend/dist/main.js --name "vtj-pro-api"
后端日志通常输出到 logs/ 或 _logs/ 目录,这些目录已被版本控制系统排除。
上传的文件和生成的项目 ZIP 包存储在 backend/uploadfiles/ 中。Nginx 配置通过 /uploadfiles/ 别名直接提供这些文件,以减少 Node.js 进程的负载。
平台提供了自动化生成生产就绪 ZIP 包的脚本。主要有两种部署变体:完整版 和 云版。
发布过程由 scripts/publish.mjs 处理(文档中提及),该脚本整合了前端构建、后端构建以及必要的模板。
代码到产物的映射
| 变体 | 目标环境 | 描述 |
|---|---|---|
| 完整版 | 私有云 / 本地部署 | 包含所有依赖、本地存储驱动以及完整的模板库。 |
| 云版 | 托管式 SaaS | 针对云环境优化,通常依赖外部对象存储服务(OSS)而非本地的 uploadfiles。 |
应用程序通过 .env 文件和 Vite 特定的模式文件区分开发环境和生产环境。
后端使用环境变量配置:
AUTH_CODE 和 JWT 密钥。Vite 环境文件(如 .env.production)控制 VITE_API_URL 和 VITE_SDK_URL。在构建过程中,这些变量会被注入到 frontend/dist 的静态资源中。
为准备新的构建或部署,可使用 clean.mjs 脚本(文档中提及)清除构建产物和临时文件。
日志生成位置如下:
/var/log/nginx/logs/ 文件夹中。www-data 用户运行 Nginx。