挂载方式部署项目

一、核心思想

  • 不把前端文件打包进镜像,而是使用官方 Nginx 镜像
  • 通过 -v(或 --volume)参数,将主机上的 dist/ 目录挂载到容器内的 Nginx 默认 Web 根目录(如 /usr/share/nginx/html
  • Nginx 配置可通过挂载自定义配置文件实现反向代理等逻辑

💡 优点:修改前端文件无需重建镜像,刷新即生效

⚠️ 缺点:依赖主机路径,可移植性差,权限问题较常见


二、部署步骤(完整流程)

第 1 步:构建前端项目,生成 dist/目录

复制代码
npm run build
# 输出通常为 dist/ 或 build/

假设你的前端产物在:

复制代码
/root/wanchuang_Platform/dist/

第 2 步:准备 Nginx 配置文件( default.conf

创建 /root/wanchuang_Platform/default.conf

复制代码
server {
    listen 8085;
    server_name localhost;
    root /usr/share/nginx/html;
    index index.html;

    # 代理后端 API
    location /admin/ {
        proxy_pass http://127.0.0.1:8080;  # 若用 --network host
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }

    # 支持前端路由(如 Vue Router history 模式)
    location / {
        try_files $uri /index.html;
    }
}

第 3 步:启动容器并挂载文件和配置

复制代码
podman run -d \
  --name wanchuang_platform \
  --network host \          # 共享主机网络,便于访问后端
  -v /root/wanchuang_Platform/dist:/usr/share/nginx/html:ro,Z \  # 挂载前端文件
  -v /root/wanchuang_Platform/default.conf:/etc/nginx/conf.d/default.conf:ro,Z \  # 挂载配置
  nginx:alpine

🔑 参数说明:

  • -v 源路径:容器路径:ro,Z
    • ro:只读(安全)
    • Z:自动设置 SELinux 标签(解决权限拒绝问题,阿里云 CentOS 必加
  • --network host:让容器能通过 127.0.0.1 访问主机上的后端服务

第 4 步:访问应用

根据配置中的 listen 8085;,访问:

复制代码
http://47.116.170.161:8085/user/login
相关推荐
Pedantic几秒前
SwiftUI 手势笔记
前端·后端
橙子家30 分钟前
浏览器缓存之【结构化数据库与缓存】: IndexedDB、Cache storage 和 Storage buckets
前端
user205855615181335 分钟前
X6 中边悬浮置顶,规避 `mouseleave` 事件丢失问题
前端
李明卫杭州36 分钟前
CSS aspect-ratio 属性完全指南
前端
Pedantic3 小时前
SwiftUI 手势层级(Gesture Hierarchy)详解
前端
飘尘3 小时前
前端转型全栈(Java后端)的快速上手指引
前端·后端·全栈
一颗烂土豆3 小时前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
浏览器工程师4 小时前
AI Agent 接浏览器任务,先别让它一路点到底
前端·后端
雨季mo浅忆4 小时前
VSCode自动格式化三要素
前端