挂载方式部署项目

一、核心思想

  • 不把前端文件打包进镜像,而是使用官方 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
相关推荐
我材不敲代码18 小时前
Python 函数核心:位置参数与关键字参数详解
java·前端·python
Kratzdisteln18 小时前
【无标题】
前端·python
Curvatureflight18 小时前
前端国际化 i18n 落地实践:语言包、动态文案和格式化问题怎么处理?
前端·c++·vue
深圳市晶科鑫实业有限公司18 小时前
5G与AIoT时代:如何选择晶振常用频率?
服务器·单片机·物联网·5g·智能路由器·健康医疗·信息与通信
kTR2hD1qb19 小时前
Claude Code Skill的介绍与使用
java·前端·数据库·人工智能
修己xj19 小时前
打造专属博文封面神器:一个开源免费的博文封面生成器ThisCover
前端
kyriewen20 小时前
面试8家前端岗位后,我发现了一个残酷的事实:AI不是加分项,是门槛
前端·javascript·面试
wanhengidc20 小时前
双线服务器有哪些优点?
运维·服务器
Fighting_p20 小时前
【面试 - el-select问题及解决】wujie 微前端下子系统 el-select 多选 filterable 过滤失效
前端
吃口巧乐兹20 小时前
AI 全栈时代,为什么要服务端使用 NestJs
前端