Spaces:
Running
Running
# ---- Build Stage ---- | |
FROM node:18-alpine AS builder | |
# Install pnpm as root | |
RUN corepack enable && corepack prepare pnpm@10.10.0 --activate | |
USER node | |
ENV HOME=/home/node \ | |
PATH=/home/node/.local/bin:$PATH | |
WORKDIR $HOME/app | |
# Install dependencies and build | |
COPY --chown=node package.json pnpm-lock.yaml* ./ | |
COPY --chown=node tsconfig.json ./ | |
COPY --chown=node src ./src | |
RUN pnpm install --frozen-lockfile | |
RUN pnpm run build | |
RUN chown -R node:node $HOME/app | |
# ---- Production Stage ---- | |
FROM node:18-alpine AS runner | |
# No need to install pnpm here, just switch to node user | |
USER node | |
ENV HOME=/home/node \ | |
PATH=/home/node/.local/bin:$PATH | |
# Create app directory | |
WORKDIR $HOME/app | |
# Copy only necessary files from builder | |
COPY --chown=node --from=builder /home/node/app/dist ./dist | |
COPY --chown=node --from=builder /home/node/app/package.json ./ | |
COPY --chown=node --from=builder /home/node/app/node_modules ./node_modules | |
# Use a non-root user for security | |
EXPOSE 3000 | |
CMD ["node", "dist/index.js"] | |