fix(2.0-services): 优化所有Dockerfile使用--chown避免chown -R

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
hailin 2026-01-10 23:23:57 -08:00
parent 81f8422758
commit d3fecc42c1
5 changed files with 132 additions and 97 deletions

View File

@ -6,43 +6,50 @@
FROM node:20-alpine AS builder FROM node:20-alpine AS builder
WORKDIR /app WORKDIR /app
RUN apk add --no-cache python3 make g++ COPY package*.json ./
COPY tsconfig*.json ./
COPY package.json package-lock.json ./
RUN npm ci
COPY prisma ./prisma/ COPY prisma ./prisma/
RUN npx prisma generate
COPY . . RUN npm ci
RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY src ./src
RUN npm run build RUN npm run build
# 阶段2: 生产运行 # 阶段2: 生产运行
FROM node:20-alpine AS runner FROM node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production RUN addgroup --system --gid 1001 nodejs && \
ENV TZ=Asia/Shanghai adduser --system --uid 1001 -G nodejs nestjs
RUN apk add --no-cache curl tzdata RUN apk add --no-cache curl tzdata
RUN addgroup --system --gid 1001 nodejs && \ RUN mkdir -p /app && chown nestjs:nodejs /app
adduser --system --uid 1001 nestjs WORKDIR /app
COPY package.json package-lock.json ./ USER nestjs
COPY --chown=nestjs:nodejs package*.json ./
RUN npm ci --only=production && npm cache clean --force RUN npm ci --only=production && npm cache clean --force
COPY prisma ./prisma/ COPY --chown=nestjs:nodejs prisma ./prisma/
RUN npx prisma generate RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY --from=builder /app/dist ./dist COPY --chown=nestjs:nodejs --from=builder /app/dist ./dist
RUN chown -R nestjs:nodejs /app RUN echo '#!/bin/sh\n\
USER nestjs set -e\n\
echo "Running database migrations..."\n\
npx prisma migrate deploy\n\
echo "Starting application..."\n\
exec node dist/main.js\n' > /app/start.sh && chmod +x /app/start.sh
ENV NODE_ENV=production
ENV TZ=Asia/Shanghai
EXPOSE 3024 EXPOSE 3024
HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \ HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \
CMD curl -f http://localhost:3024/api/v2/health || exit 1 CMD curl -f http://localhost:3024/api/v2/health || exit 1
CMD ["node", "dist/main.js"] CMD ["/app/start.sh"]

View File

@ -6,43 +6,50 @@
FROM node:20-alpine AS builder FROM node:20-alpine AS builder
WORKDIR /app WORKDIR /app
RUN apk add --no-cache python3 make g++ COPY package*.json ./
COPY tsconfig*.json ./
COPY package.json package-lock.json ./
RUN npm ci
COPY prisma ./prisma/ COPY prisma ./prisma/
RUN npx prisma generate
COPY . . RUN npm ci
RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY src ./src
RUN npm run build RUN npm run build
# 阶段2: 生产运行 # 阶段2: 生产运行
FROM node:20-alpine AS runner FROM node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production RUN addgroup --system --gid 1001 nodejs && \
ENV TZ=Asia/Shanghai adduser --system --uid 1001 -G nodejs nestjs
RUN apk add --no-cache curl tzdata RUN apk add --no-cache curl tzdata
RUN addgroup --system --gid 1001 nodejs && \ RUN mkdir -p /app && chown nestjs:nodejs /app
adduser --system --uid 1001 nestjs WORKDIR /app
COPY package.json package-lock.json ./ USER nestjs
COPY --chown=nestjs:nodejs package*.json ./
RUN npm ci --only=production && npm cache clean --force RUN npm ci --only=production && npm cache clean --force
COPY prisma ./prisma/ COPY --chown=nestjs:nodejs prisma ./prisma/
RUN npx prisma generate RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY --from=builder /app/dist ./dist COPY --chown=nestjs:nodejs --from=builder /app/dist ./dist
RUN chown -R nestjs:nodejs /app RUN echo '#!/bin/sh\n\
USER nestjs set -e\n\
echo "Running database migrations..."\n\
npx prisma migrate deploy\n\
echo "Starting application..."\n\
exec node dist/main.js\n' > /app/start.sh && chmod +x /app/start.sh
ENV NODE_ENV=production
ENV TZ=Asia/Shanghai
EXPOSE 3020 EXPOSE 3020
HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \ HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \
CMD curl -f http://localhost:3020/health || exit 1 CMD curl -f http://localhost:3020/health || exit 1
CMD ["node", "dist/main.js"] CMD ["/app/start.sh"]

View File

@ -6,43 +6,50 @@
FROM node:20-alpine AS builder FROM node:20-alpine AS builder
WORKDIR /app WORKDIR /app
RUN apk add --no-cache python3 make g++ COPY package*.json ./
COPY tsconfig*.json ./
COPY package.json package-lock.json ./
RUN npm ci
COPY prisma ./prisma/ COPY prisma ./prisma/
RUN npx prisma generate
COPY . . RUN npm ci
RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY src ./src
RUN npm run build RUN npm run build
# 阶段2: 生产运行 # 阶段2: 生产运行
FROM node:20-alpine AS runner FROM node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production RUN addgroup --system --gid 1001 nodejs && \
ENV TZ=Asia/Shanghai adduser --system --uid 1001 -G nodejs nestjs
RUN apk add --no-cache curl tzdata RUN apk add --no-cache curl tzdata
RUN addgroup --system --gid 1001 nodejs && \ RUN mkdir -p /app && chown nestjs:nodejs /app
adduser --system --uid 1001 nestjs WORKDIR /app
COPY package.json package-lock.json ./ USER nestjs
COPY --chown=nestjs:nodejs package*.json ./
RUN npm ci --only=production && npm cache clean --force RUN npm ci --only=production && npm cache clean --force
COPY prisma ./prisma/ COPY --chown=nestjs:nodejs prisma ./prisma/
RUN npx prisma generate RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY --from=builder /app/dist ./dist COPY --chown=nestjs:nodejs --from=builder /app/dist ./dist
RUN chown -R nestjs:nodejs /app RUN echo '#!/bin/sh\n\
USER nestjs set -e\n\
echo "Running database migrations..."\n\
npx prisma migrate deploy\n\
echo "Starting application..."\n\
exec node dist/main.js\n' > /app/start.sh && chmod +x /app/start.sh
ENV NODE_ENV=production
ENV TZ=Asia/Shanghai
EXPOSE 3021 EXPOSE 3021
HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \ HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \
CMD curl -f http://localhost:3021/health || exit 1 CMD curl -f http://localhost:3021/health || exit 1
CMD ["node", "dist/main.js"] CMD ["/app/start.sh"]

View File

@ -2,47 +2,54 @@
# Mining Wallet Service - Dockerfile # Mining Wallet Service - Dockerfile
# ============================================================================= # =============================================================================
# Stage 1: Build # 阶段1: 构建
FROM node:20-alpine AS builder FROM node:20-alpine AS builder
WORKDIR /app WORKDIR /app
RUN apk add --no-cache python3 make g++ COPY package*.json ./
COPY tsconfig*.json ./
COPY package.json package-lock.json ./
RUN npm ci
COPY prisma ./prisma/ COPY prisma ./prisma/
RUN npx prisma generate
COPY . . RUN npm ci
RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY src ./src
RUN npm run build RUN npm run build
# Stage 2: Production # 阶段2: 生产运行
FROM node:20-alpine AS runner FROM node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production RUN addgroup --system --gid 1001 nodejs && \
ENV TZ=Asia/Shanghai adduser --system --uid 1001 -G nodejs nestjs
RUN apk add --no-cache curl tzdata RUN apk add --no-cache curl tzdata
RUN addgroup --system --gid 1001 nodejs && \ RUN mkdir -p /app && chown nestjs:nodejs /app
adduser --system --uid 1001 nestjs WORKDIR /app
COPY package.json package-lock.json ./ USER nestjs
COPY --chown=nestjs:nodejs package*.json ./
RUN npm ci --only=production && npm cache clean --force RUN npm ci --only=production && npm cache clean --force
COPY prisma ./prisma/ COPY --chown=nestjs:nodejs prisma ./prisma/
RUN npx prisma generate RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY --from=builder /app/dist ./dist COPY --chown=nestjs:nodejs --from=builder /app/dist ./dist
RUN chown -R nestjs:nodejs /app RUN echo '#!/bin/sh\n\
USER nestjs set -e\n\
echo "Running database migrations..."\n\
npx prisma migrate deploy\n\
echo "Starting application..."\n\
exec node dist/main.js\n' > /app/start.sh && chmod +x /app/start.sh
ENV NODE_ENV=production
ENV TZ=Asia/Shanghai
EXPOSE 3025 EXPOSE 3025
HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \ HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \
CMD curl -f http://localhost:3025/health || exit 1 CMD curl -f http://localhost:3025/health || exit 1
CMD ["node", "dist/main.js"] CMD ["/app/start.sh"]

View File

@ -6,43 +6,50 @@
FROM node:20-alpine AS builder FROM node:20-alpine AS builder
WORKDIR /app WORKDIR /app
RUN apk add --no-cache python3 make g++ COPY package*.json ./
COPY tsconfig*.json ./
COPY package.json package-lock.json ./
RUN npm ci
COPY prisma ./prisma/ COPY prisma ./prisma/
RUN npx prisma generate
COPY . . RUN npm ci
RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY src ./src
RUN npm run build RUN npm run build
# 阶段2: 生产运行 # 阶段2: 生产运行
FROM node:20-alpine AS runner FROM node:20-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production RUN addgroup --system --gid 1001 nodejs && \
ENV TZ=Asia/Shanghai adduser --system --uid 1001 -G nodejs nestjs
RUN apk add --no-cache curl tzdata RUN apk add --no-cache curl tzdata
RUN addgroup --system --gid 1001 nodejs && \ RUN mkdir -p /app && chown nestjs:nodejs /app
adduser --system --uid 1001 nestjs WORKDIR /app
COPY package.json package-lock.json ./ USER nestjs
COPY --chown=nestjs:nodejs package*.json ./
RUN npm ci --only=production && npm cache clean --force RUN npm ci --only=production && npm cache clean --force
COPY prisma ./prisma/ COPY --chown=nestjs:nodejs prisma ./prisma/
RUN npx prisma generate RUN DATABASE_URL="postgresql://user:pass@localhost:5432/db" npx prisma generate
COPY --from=builder /app/dist ./dist COPY --chown=nestjs:nodejs --from=builder /app/dist ./dist
RUN chown -R nestjs:nodejs /app RUN echo '#!/bin/sh\n\
USER nestjs set -e\n\
echo "Running database migrations..."\n\
npx prisma migrate deploy\n\
echo "Starting application..."\n\
exec node dist/main.js\n' > /app/start.sh && chmod +x /app/start.sh
ENV NODE_ENV=production
ENV TZ=Asia/Shanghai
EXPOSE 3022 EXPOSE 3022
HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \ HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \
CMD curl -f http://localhost:3022/health || exit 1 CMD curl -f http://localhost:3022/health || exit 1
CMD ["node", "dist/main.js"] CMD ["/app/start.sh"]