# Multi-stage # 1) Node image for building frontend assets # 2) nginx stage to serve frontend assets # Name the node stage "builder" FROM node:16 AS builder # Set working directory WORKDIR /app ARG VITE_BACKEND_DOMAIN ARG VITE_INSTANCE_DOMAIN ARG VITE_HTTPS ENV VITE_BACKEND_DOMAIN $VITE_BACKEND_DOMAIN ENV VITE_INSTANCE_DOMAIN $VITE_INSTANCE_DOMAIN ENV VITE_HTTPS $VITE_HTTPS # Copy all files from current directory to working dir in image COPY . . # install node modules and build assets RUN npm i && npm run build # nginx state for serving content FROM nginx:alpine COPY ./nginx.conf /etc/nginx/nginx.conf # Set working directory to nginx asset directory WORKDIR /usr/share/nginx/html # Remove default nginx static assets RUN rm -rf ./* # Copy static assets from builder stage COPY --from=builder /app/dist . # Containers run nginx with global directives and daemon off EXPOSE 80 ENTRYPOINT ["nginx", "-g", "daemon off;"]