리액트 PWA, NginX, Docker를 이용하여 두개의 프론트 프로젝트 ec2에 배포

Consumer

server {
    listen 5173;

    location / {
        root    /usr/share/nginx/html;
        index   index.html;

        try_files $uri $uri/ /consumer/index.html;
    }
}
# 1단계: 애플리케이션 빌드
FROM node:20.11.0 as builder
WORKDIR /app

# 필요한 파일들 복사
COPY package*.json ./
RUN npm install

# 빌드 수행
COPY . .
RUN npm run build || exit 1

# nginx 이미지를 사용 (뒤에 tag가 없으면 latest를 사용)
FROM nginx

# 빌드된 애플리케이션 복사
COPY --from=builder /app/dist /usr/share/nginx/html/consumer

# nginx 의 default.conf를 삭제
RUN rm /etc/nginx/conf.d/default.conf

# host pc 의 nginx.conf를 복사
COPY ./nginx.conf /etc/nginx/conf.d/nginx.conf

# 5173 포트 오픈
EXPOSE 5173

# nginx 시작
CMD ["nginx", "-g", "daemon off;"]

Seller

server {
    listen 5174;

    location / {
        root    /usr/share/nginx/html;
        index   index.html;
        try_files $uri $uri/ /seller/index.html;
    }
}
# 1단계: 애플리케이션 빌드
FROM node:20.11.0 as builder
WORKDIR /app

# 필요한 파일들 복사
COPY package*.json ./
RUN npm install

# 빌드 수행
COPY . .
RUN npm run build || exit 1

# nginx 이미지를 사용 (뒤에 tag가 없으면 latest를 사용)
FROM nginx

# 빌드된 애플리케이션 복사
COPY --from=builder /app/dist /usr/share/nginx/html/seller

# nginx 의 default.conf를 삭제
RUN rm /etc/nginx/conf.d/default.conf

# host pc 의 nginx.conf를 복사
COPY ./nginx.conf /etc/nginx/conf.d/nginx.conf

# 5174 포트 오픈
EXPOSE 5174

# nginx 시작
CMD ["nginx", "-g", "daemon off;"]