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

AI问答-vue3+ts+vite:http://www.abc.com:3022/m-abc-pc/#/snow 这样的项目 在服务器怎么部署

为什么记录有子路径项目的部署,因为,通过子路径可以区分项目,那么也就可以实现微前端架构,并且具有独特优势,每个项目都是绝对隔离的。

要将 Vue3 项目(如路径为 http://www.abc.com:3022/m-saas-pc/#/snow)部署到服务器,需确保静态资源正确托管并配置路由回退,以下是详细步骤和注意事项:

一、 构建生产环境静态文件

1.1、执行构建命令

在项目根目录运行以下命令,生成 dist 文件夹(包含优化后的 HTML、CSS、JS):

npm run build

1.2、关键配置

vue.config.js(若使用 Vue CLI):

确保 publicPath 配置正确。若项目部署在子路径(如 /m-abc-pc),需设置:

export default defineConfig({base: '/m-abc-pc/', // 部署的子路径 / 指定静态资源的基础路径
}}

1.3、路由模式

若使用 history 模式(无 #),需额外配置服务器;若使用 hash 模式(有 #),则无需修改路由配置。

二、部署静态文件到服务器

2.1、选择服务器

Nginx(推荐):高性能、易配置。

Apache:需配置 .htaccess。

云服务:如阿里云 OSS、腾讯云 COS(需额外配置 CDN 和回源规则)。

2.2、上传文件

将 dist 文件夹内容上传到服务器指定目录(如 /var/www/m-abc-pc)。

三、配置服务器(以 Nginx 为例)

3.1、安装 Nginx

sudo apt update && sudo apt install nginx -y

3.2、配置虚拟主机

编辑 Nginx 配置文件(如 /etc/nginx/sites-available/m-abc-pc):

server {listen 80;server_name your_domain.com; # 替换为你的域名或服务器 IProot /var/www/m-abc-pc; # 指向 dist 文件夹index index.html;location / {try_files $uri $uri/ /index.html; # 关键:处理前端路由}
}

3.3、启用配置并重启 Nginx

sudo ln -s /etc/nginx/sites-available/m-abc-pc /etc/nginx/sites-enabled
sudo nginx -t # 测试配置
sudo systemctl restart nginx

4. 验证部署

4.1、访问项目

通过浏览器访问 http://your_domain.com/m-abc-pc/#/snow,确认页面正常加载且路由跳转无问题。

4.2、常见问题排查

404 错误:检查 try_files 配置是否正确。

资源路径错误:确认 publicPath 与部署路径一致。

跨域问题:若后端 API 跨域,需在服务器或后端配置 CORS。


5. 高级配置(可选)

5.1、HTTPS 配置

HTTPS 配置:
使用 Let's Encrypt 免费证书:
sudo apt install certbot python3-certbot-nginx -y
sudo certbot --nginx -d your_domain.com

5.2、CDN 加速

将静态资源托管到 CDN(如 Cloudflare),减少服务器压力。

5.3、自动化部署

使用 CI/CD 工具(如 GitHub Actions)自动化构建和部署流程。

六、总结

构建静态文件:确保 publicPath 和路由模式正确。

上传文件:将 dist 文件夹上传到服务器。

配置服务器:使用 Nginx 或其他服务器配置静态资源托管和路由回退。

验证和优化:检查访问是否正常,并配置 HTTPS 和 CDN(可选)。

通过以上步骤,你的 Vue3 项目即可在服务器上正常运行,并支持 hash 模式的路由跳转。

七、欢迎交流指正

http://www.lryc.cn/news/2403404.html

相关文章:

  • 当主观认知遇上机器逻辑:减少大模型工程化中的“主观性”模糊
  • 会计 - 金融负债和权益工具
  • .net Span类型和Memory类型
  • Dify工具插件开发和智能体开发全流程
  • ES6——对象扩展之Set对象
  • AI书签管理工具开发全记录(十三):TUI基本框架搭建
  • <2>-MySQL库的操作
  • Apache DolphinScheduler 和 Apache Airflow 对比
  • 初识结构体,整型提升及操作符的属性
  • 检测到 #include 错误。请更新 includePath。已为此翻译单元(D:\软件\vscode\test.c)禁用波形曲线
  • python --导出数据库表结构(pymysql)
  • 如何自动部署GitLab项目
  • 在 Windows 系统上运行 Docker 容器中的 Ubuntu 镜像并显示 GUI
  • 基于 COM 的 XML 解析技术(MSXML) 的总结
  • 多分辨率 LCD 的 GUI 架构设计与实现
  • 2025年,百度智能云打响AI落地升维战
  • Seed1.5-VL登顶,国产闭源模型弯道超车丨多模态模型5月最新榜单揭晓
  • SON.stringify()和JSON.parse()之间的转换
  • 【学习笔记】构造函数+重载相关
  • JVM——打开JVM后门的钥匙:反射机制
  • 第3章——SSM整合
  • VTK 显示文字、图片及2D/3D图
  • 小白如何在cursor中使用mcp服务——以使用notion的api为例
  • 引领AI安全新时代 Accelerate 2025北亚巡展·北京站成功举办
  • 为什么说数列是特殊的函数
  • 解决uniapp开发app map组件最高层级 遮挡自定义解决底部tabbar方法
  • 96. 2017年蓝桥杯省赛 - Excel地址(困难)- 进制转换
  • PPT转图片拼贴工具 v1.0
  • 大模型在脑梗塞后遗症风险预测及治疗方案制定中的应用研究
  • Qwen2.5-VL - 模型结构