Dockerupdate
This commit is contained in:
60
Dockerfile
60
Dockerfile
@ -1,18 +1,58 @@
|
|||||||
FROM node:18 AS build
|
# syntax=docker/dockerfile:1.4
|
||||||
|
|
||||||
|
# 1. For build React app
|
||||||
|
FROM node:lts AS development
|
||||||
|
|
||||||
|
# Set working directory
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
|
|
||||||
# Copy only package files first (better caching)
|
#
|
||||||
COPY package*.json ./
|
COPY package.json /app/package.json
|
||||||
|
COPY package-lock.json /app/package-lock.json
|
||||||
|
|
||||||
# This layer will be cached if package.json doesn't change
|
# Same as npm install
|
||||||
RUN npm ci --legacy-peer-deps
|
RUN npm ci
|
||||||
|
|
||||||
|
COPY . /app
|
||||||
|
|
||||||
|
ENV CI=true
|
||||||
|
ENV PORT=3000
|
||||||
|
|
||||||
|
CMD [ "npm", "start" ]
|
||||||
|
|
||||||
|
FROM development AS build
|
||||||
|
|
||||||
# Copy source code (this changes more often)
|
|
||||||
COPY . .
|
|
||||||
RUN npm run build
|
RUN npm run build
|
||||||
|
|
||||||
|
|
||||||
|
FROM development as dev-envs
|
||||||
|
RUN <<EOF
|
||||||
|
apt-get update
|
||||||
|
apt-get install -y --no-install-recommends git
|
||||||
|
EOF
|
||||||
|
|
||||||
|
RUN <<EOF
|
||||||
|
useradd -s /bin/bash -m vscode
|
||||||
|
groupadd docker
|
||||||
|
usermod -aG docker vscode
|
||||||
|
EOF
|
||||||
|
# install Docker tools (cli, buildx, compose)
|
||||||
|
COPY --from=gloursdocker/docker / /
|
||||||
|
CMD [ "npm", "start" ]
|
||||||
|
|
||||||
|
# 2. For Nginx setup
|
||||||
FROM nginx:alpine
|
FROM nginx:alpine
|
||||||
COPY --from=build /app/public /usr/share/nginx/html
|
|
||||||
RUN echo 'server { listen 80; root /usr/share/nginx/html; index index.html; location / { try_files $uri $uri/ /index.html; } }' > /etc/nginx/conf.d/default.conf
|
# Copy config nginx
|
||||||
EXPOSE 80
|
COPY --from=build /app/.nginx/nginx.conf /etc/nginx/conf.d/default.conf
|
||||||
|
|
||||||
|
WORKDIR /usr/share/nginx/html
|
||||||
|
|
||||||
|
# Remove default nginx static assets
|
||||||
|
RUN rm -rf ./*
|
||||||
|
|
||||||
|
# Copy static assets from builder stage
|
||||||
|
COPY --from=build /app/build .
|
||||||
|
|
||||||
|
# Containers run nginx with global directives and daemon off
|
||||||
|
ENTRYPOINT ["nginx", "-g", "daemon off;"]
|
||||||
Reference in New Issue
Block a user