挂载方式部署项目

一、核心思想

  • 不把前端文件打包进镜像,而是使用官方 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
相关推荐
Hello World . .21 小时前
Linux驱动编程1:imxull上移植Linux系统
linux·运维·服务器
sycmancia21 小时前
Qt——布局管理器(一)
前端·qt
IMPYLH21 小时前
Linux 的 numfmt 命令
linux·运维·服务器·bash
peak_chan21 小时前
通过vue-virtual-scroller封装虚拟滚动el-select
前端·javascript·vue.js
sunz_dragon21 小时前
Claude Code / Codex Git 版本管理完整使用指南
服务器·人工智能
小李子呢02111 天前
前端八股Vue(7)---computed计算属性和watch侦听器
前端·javascript·vue.js
CCIE-Yasuo1 天前
Win11-Microsoft Edge使用起来CPU飙升以及卡顿问题解决
前端·microsoft·edge·排故
SPC的存折1 天前
3、主从复制实现同步数据过滤
linux·运维·服务器
SPC的存折1 天前
openEuler 24.03 MariaDB Galera 集群部署指南(cz)
linux·运维·服务器·数据库·mysql
SPC的存折1 天前
MySQL 8.0 分库分表
linux·运维·服务器·数据库·mysql