mirror of
https://github.com/setube/ogame-vue-ts.git
synced 2026-05-11 23:45:11 +08:00
feat(docker): 优化Docker构建流程并支持生产环境部署
- 引入多阶段构建,分离构建与运行时环境 - 使用node:20-alpine作为构建基础镜像,减小体积 - 添加pnpm包管理器并优化依赖安装流程 - 利用缓存机制提升构建效率 - 新增nginx.conf配置文件解决Vue Router历史模式404问题 - 设置静态资源缓存策略提升性能 - 更改默认启动命令为Nginx服务方式运行应用 - 移除开发服务器相关指令,适配生产部署需求
This commit is contained in:
36
Dockerfile
36
Dockerfile
@@ -1,17 +1,33 @@
|
|||||||
FROM node:latest
|
# ========= 阶段1:构建 =========
|
||||||
|
FROM node:20-alpine AS builder
|
||||||
RUN mkdir -p /workspace
|
|
||||||
|
|
||||||
WORKDIR /workspace
|
|
||||||
|
|
||||||
|
# 使用国内镜像加速(可选)
|
||||||
RUN npm config set registry https://registry.npmmirror.com
|
RUN npm config set registry https://registry.npmmirror.com
|
||||||
|
|
||||||
RUN cd /workspace
|
WORKDIR /app
|
||||||
|
|
||||||
RUN git clone https://github.com/setube/ogame-vue-ts.git
|
# 先复制依赖文件,利用缓存
|
||||||
|
COPY package.json pnpm-lock.yaml* ./
|
||||||
|
|
||||||
RUN mv ./ogame-vue-ts/* . ; rm -rf ./ogame-vue-ts/
|
# 安装 pnpm 并安装依赖
|
||||||
|
RUN corepack enable && corepack prepare pnpm@latest --activate \
|
||||||
|
&& pnpm install --frozen-lockfile
|
||||||
|
|
||||||
RUN npm install -g pnpm ; pnpm install ; npx vite build
|
# 复制源码
|
||||||
|
COPY . .
|
||||||
|
|
||||||
CMD ["npx", "vite", "preview", "--host", "0.0.0.0", "--port", "25121"]
|
# 生产构建
|
||||||
|
RUN pnpm run build
|
||||||
|
|
||||||
|
# ========= 阶段2:运行时 =========
|
||||||
|
FROM nginx:alpine
|
||||||
|
|
||||||
|
# 复制构建产物
|
||||||
|
COPY --from=builder /app/dist /usr/share/nginx/html
|
||||||
|
|
||||||
|
# 解决 Vue Router history 模式 404 问题
|
||||||
|
COPY nginx.conf /etc/nginx/conf.d/default.conf
|
||||||
|
|
||||||
|
EXPOSE 80
|
||||||
|
|
||||||
|
CMD ["nginx", "-g", "daemon off;"]
|
||||||
17
nginx.conf
Normal file
17
nginx.conf
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name localhost;
|
||||||
|
|
||||||
|
root /usr/share/nginx/html;
|
||||||
|
index index.html index.htm;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
try_files $uri $uri/ /index.html;
|
||||||
|
}
|
||||||
|
|
||||||
|
# 可选:缓存静态资源
|
||||||
|
location ~* \.(js|css|png|jpg|jpeg|gif|ico|svg|woff2?|ttf|eot) {
|
||||||
|
expires 1y;
|
||||||
|
add_header Cache-Control "public, immutable";
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user