懒猫微服进阶心得(六):以纸砚双拼为例,快速移植纯前端项目到懒猫微服

之前移植了一款颜值极高的纸砚双拼,想着纯前端类的软件应该都是一样的操作,所以把操作记录下来,方便以后复习查看,也相当于一个教程吧。

image-20250531195827292

对于这种场景来说,前端项目开发完成后,我们将构建好的静态页面部署到服务器上。借助 Docker 和 Nginx,可以实现一套轻量、快速、可移植的部署方式,特别适合懒猫微服这种容器化的环境,也很适合日常调试测试使用。

下面将手把手教你如何打包一个 Vue 或 React 项目,并通过 Docker + Nginx 构建一个可复用的前端部署容器镜像,然后就可以把这个部署到懒猫微服删,当然也适用于各种 Linux + Docker 环境。


1 · 准备目录结构

纸砚双拼是 Vue 的项目,所以直接执行这个命令打包

1
2
npm i
npm run build

打包完成后,项目根目录下会生成一个 dist/ 文件夹,里面包含:

  • index.html
  • 静态 JS、CSS 资源
  • 图片等其他引用资源

基本所有前端工程化的流程都是部署这个 dist/静态目录。

在开始容器化之前,我们先来整理一下项目结构。

1
2
3
4
5
my-static-site/
├── dist/ # 前端打包后的静态资源目录
├── nginx.conf # Nginx 配置文件
├── Dockerfile # Docker 构建文件
└── docker-compose.yml # docker-compose 管理配置(可选)

主要就是把 dist/ 目录映射到 Nginx 的根目录。

.dockerignore(防止把 node_modules 等大文件复制进镜像)

项目根目录建议加个 .dockerignore 文件,防止无用文件进入镜像、浪费空间:

1
2
3
4
5
node_modules
.git
.vscode
*.log
dist

这里的 dist 虽然是构建产物,但因为我们用的是双阶段构建,会在容器里重新生成,不需要提前放入。

2 · Dockerfile(双阶段构建:先构建,再用 Nginx 托管)

我们采用双阶段构建方案,能够最大限度减小最终镜像体积,只包含运行时必须的内容。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
# 构建阶段
FROM node:18-alpine AS build

WORKDIR /app

# 复制package.json和package-lock.json
COPY package*.json ./

# 安装依赖 - 使用npm install代替npm ci
RUN npm install

# 复制源代码
COPY . .

# 构建应用
RUN npm run build

# 生产阶段
FROM nginx:alpine

# 复制构建产物到nginx目录
COPY --from=build /app/build /usr/share/nginx/html

# 复制nginx配置
COPY nginx.conf /etc/nginx/conf.d/default.conf

# 暴露80端口
EXPOSE 80

# 启动nginx
CMD ["nginx", "-g", "daemon off;"]
  • 使用 node:alpinenginx:alpine 轻量镜像,构建出来的镜像体积非常小
  • 分阶段构建,确保生产镜像中没有多余文件

nginx.conf(自定义 Nginx 配置)

Nginx 配置文件如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
server {
listen 80;
server_name localhost;

location / {
root /usr/share/nginx/html;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}

# 禁止缓存 index.html,确保始终获取最新版本(避免缓存导致更新不生效)
location = /index.html {
root /usr/share/nginx/html;
add_header Cache-Control "no-store, no-cache, must-revalidate";
}

# 静态资源缓存设置
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg)$ {
root /usr/share/nginx/html;
expires 1d;
}

error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}

3 · 构建与部署

3.1 本地构建测试

执行以下命令构建镜像并启动:

1
2
docker build -t my-frontend .
docker run -p 8080:80 my-frontend

打开浏览器访问 http://localhost:8080,确认页面正常显示。如果用的是懒猫微服,可通过它的 web 浏览器或 ssh 转发方式访问容器。

3.2 可选使用 docker-compose

如果本地调试可以使用

1
2
3
4
5
6
7
8
9
10
version: "3"

services:
cors-tester:
build:
context: .
dockerfile: Dockerfile
ports:
- "80:80"
restart: unless-stopped

之前打包踩的坑

打包多了之后 Docker 会积累不少旧镜像、缓存和挂载卷,下面这些命令能够清理磁盘空间:

使用 pg-docker 或者 lzc-docker 来替代

强制无缓存构建镜像

1
docker compose build --no-cache

不使用任何缓存,适合依赖变动或调试构建问题时使用。

📦 查看磁盘空间占用详情

1
docker system df -v

查看镜像、容器、网络和卷的占用情况,排查“空间去哪了”。

🧹 强制清理所有未使用资源(含挂载卷)

1
docker system prune -af --volumes

image-20250603161544308

删除所有未使用的镜像、容器、网络和卷,释放最大磁盘空间。
注意:慎用,可能会清掉你没保存的 volume 数据。

懒猫微服进阶心得(六):以纸砚双拼为例,快速移植纯前端项目到懒猫微服

https://xu-hardy.github.io/懒猫微服进阶心得(六):以纸砚双拼为例,快速移植纯前端项目到懒猫微服/

作者

Xu

发布于

2025-07-02

更新于

2025-07-01

许可协议

评论