在阿里云上部署 Vue 或 React 项目有多种便捷方式,可以根据你的技术栈、运维经验以及项目规模选择合适的方法。以下是几种常见且高效的部署方案:
✅ 方式一:使用 阿里云静态网站托管(OSS + CDN) —— 最推荐(适合纯前端项目)
适用于不需要后端服务的 Vue/React 单页应用(SPA),是最简单、成本低、性能好的方案。
步骤:
-
构建项目
npm run build # 输出目录通常是 dist/ -
创建 OSS Bucket
- 登录 阿里云 OSS 控制台
- 创建一个 Bucket(建议开启“读写权限”为公共读)
- 进入 Bucket 设置 → 静态页面 → 启用静态网站托管
- 默认首页:
index.html - 错误页:也设置为
index.html(用于支持前端路由如 Vue Router / React Router 的 history 模式)
- 默认首页:
-
上传文件
- 使用 OSS 控制台或工具(如 ossutil、OSS Browser)上传
dist/*文件到 Bucket。 - 设置所有文件的 Content-Type(尤其是
.js,.css,.html)正确,避免浏览器解析错误。
- 使用 OSS 控制台或工具(如 ossutil、OSS Browser)上传
-
(可选)配置 CDN 提速
- 在 CDN 控制台添加域名,源站指向 OSS 域名。
- 支持 HTTPS、缓存策略优化等。
✅ 优点:
- 成本极低(按存储和流量计费)
- 高可用、高并发
- 支持 HTTPS、CDN 提速
- 无需服务器维护
❌ 限制:
- 不支持动态后端逻辑(如 Node.js API)
✅ 方式二:使用 函数计算 FC + API 网关 —— Serverless 部署
适合前后端一体化或需要轻量后端的场景。
方案 A:前端静态资源仍放 OSS,后端 API 用函数计算
- 前端:OSS 托管
- 后端:Node.js 函数部署在函数计算(FC),通过 API 网关暴露接口
方案 B:全站用函数计算(适合 SSR 或全栈项目)
- 使用 Express/Koa + Vue/React SSR,打包成函数部署到 FC
- 通过 API 网关访问
📌 工具推荐:
- 使用 Serverless Devs 或 Funcraft 快速部署:
# 示例:使用 Funcraft 部署 Node.js 应用 fun deploy
✅ 优点:
- 无需管理服务器
- 自动伸缩、按需付费
- 快速上线
✅ 方式三:ECS 云服务器部署(传统方式)
适合已有服务器运维能力,或需要完整控制环境的团队。
步骤:
-
购买 ECS 实例(Linux 推荐 CentOS/Ubuntu)
-
安装 Nginx
sudo apt update && sudo apt install nginx -y -
构建项目并上传
dist/到服务器 -
配置 Nginx:
server { listen 80; server_name your-domain.com; root /var/www/html; index index.html; location / { try_files $uri $uri/ /index.html; } } -
启动 Nginx,绑定域名,配置 SSL(可用阿里云免费证书)
✅ 优点:
- 完全可控
- 可同时部署后端服务(如 Node.js、Java)
❌ 缺点:
- 需要运维
- 成本相对较高(固定费用)
✅ 方式四:使用 云效 + 部署服务(如云·效流水线)
实现 CI/CD 自动化部署。
流程:
- 代码推送到 Git 仓库(如 GitHub、Gitee、阿里云 Code)
- 云效监听代码变更,自动执行:
npm installnpm run build- 将
dist/上传到 OSS 或部署到 ECS
- 自动发布
📌 优势:持续集成、减少人工操作、提升效率
✅ 方式五:容器化部署(ACK 或 容器实例)
适合微服务架构或 Kubernetes 用户。
- 使用 Docker 打包前端应用:
FROM nginx:alpine COPY dist /usr/share/nginx/html COPY nginx.conf /etc/nginx/nginx.conf EXPOSE 80 CMD ["nginx", "-g", "daemon off;"] - 推送镜像到 容器镜像服务 ACR
- 部署到 容器服务 Kubernetes 版(ACK) 或 弹性容器实例(ECI)
总结:推荐选择
| 场景 | 推荐方式 |
|---|---|
| 纯前端 SPA(Vue/React) | ✅ OSS + CDN(最简单高效) |
| 前后端分离,后端轻量 | ✅ OSS 托管前端 + 函数计算(FC)做 API |
| 需要完整服务器控制 | ✅ ECS + Nginx |
| 自动化部署需求 | ✅ 云效 CI/CD + OSS/ECS |
| 微服务/容器化架构 | ✅ Docker + ACK/ACR |
小贴士
- 所有方式都建议绑定自定义域名,并申请阿里云免费 SSL 证书启用 HTTPS。
- 开启 Gzip 压缩(Nginx/OSS/CDN 都支持)提升加载速度。
- 使用
history模式的路由时,确保服务器或 OSS 正确重定向到index.html。
如果你提供具体的技术栈(比如是否带后端、是否需要 SSR),我可以给出更精准的部署建议。
CLOUD技术笔记