강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

김태환님의 프로필 이미지
김태환

작성한 질문수

비전공자도 이해할 수 있는 Docker 입문/실전

[실습] Docker Compose로 백엔드(Nest.js) 실행시키기

jar 파일 생성과 컨테이너 생성 순서

작성

·

68

·

수정됨

1

이번 강의에서 NestJS는 컨테이너를 생성하면서 npm install + npm run build로 컨테이너 내에서 애플리케이션을 빌드하는 것을 배웠습니다.

하지만 왜 Spring Boot는 컨테이너를 생성하기 전에 먼저 빌드를 하고 이 jar 파일을 컨테이너로 복사하는 것인가요?

Spring Boot도 NestJS처럼 컨테이너 내에서 빌드하면 docker compose up -d --build 전에 ./gradlew clean build도 생략할 수 있으니 더 편리하지 않을까 싶어 혹시 이유가 있는지 질문 드립니다.

 

감사합니다.

답변 2

1

JSCODE 박재성님의 프로필 이미지
JSCODE 박재성
지식공유자

안녕하세요 태환님! 예리하게 잘 질문해주셨네요:D

 

NestJS와 Spring Boot가 Docker 컨테이너 빌드 방식에서 차이를 두는 이유 중

가장 큰 이유는 빌드 속도 최적화 (Gradle 캐시 활용) 측면 때문입니다.

Spring Boot는 빌드가 무겁고 캐시 활용이 중요하기 때문에

외부에서 .jar로 빌드한 후 복사하는 방식이 일반적이며, 더 효율적이라고 판단하는 편입니다.

하지만 NestJS는 비교적 빌드가 가볍고 빠르기 때문에

Docker 내부에서 바로 빌드하는 것이 더 낫다고 판단하는 편입니다.

 

하지만 빌드 과정을 어떻게 구성할 지에 대한 건 정답이라는 건 없습니다.

태환님 말씀대로 빌드의 효율성보다 관리의 편리성이 더 낫다고 생각하신다면

Spring Boot도 NestJS처럼 컨테이너 내에서 빌드하는 식으로 코드를 짜는 것도

괜찮은 방법입니다!

 

따라서 어떻게 빌드하느냐에 따라 생기는 장단점을 고려하셔서

빌드 방법을 고려하시면 좋을 것 같습니다:D

 

이 외로 또 궁금한 점 있으시면 질문 남겨주세요ㅎㅎ

김태환님의 프로필 이미지
김태환
질문자

이 이유가 맞나 저 이유가 맞나 고민하다가 해결 못하고 잠들었는데, 빠른 답변 감사합니다!!

강의 잘 보고 있습니다 강사님!

0

안녕하세요, 인프런 AI 인턴입니다. 김태환님.

질문해주신 내용은 Docker와 관련하여 각 언어와 프레임워크의 특성 차이 때문에 발생하는 부분입니다.

NestJS와 Spring Boot의 차이점

  1. NestJS (Node.js 기반):

    • Node.js 환경에서는 Docker 컨테이너 내에서 직접 npm installnpm run build를 수행하는 관행이 흔합니다. 이는 Node.js 생태계에서 개발과 실행 환경을 동일하게 유지하기 용이하기 때문입니다.
    • 이 방식을 사용하면 프로젝트 의존성 설치 및 빌드가 Docker 이미지 생성 과정에 포함되므로, 개발자 입장에서 더 간편하게 느껴질 수 있습니다.
  2. Spring Boot (Java 기반):

    • Java 생태계에서는 종종 애플리케이션 배포와 실행을 독립적으로 관리합니다. 이 때문에 비로컬에서 개발된 빌드 결과물(JAR 파일)을 먼저 생성하고 이를 컨테이너에 복사하여 사용하는 방식이 전통적으로 사용됩니다.
    • 이는 개발, 테스트, 배포 사이클을 명확히 관리하고, 필요 시 동일한 JAR 파일을 다양한 환경에서 재사용할 수 있게 하여 관리 및 배포의 일관성을 제공합니다.

이유와 장점

  • 일관성 유지: 빌드와 실행을 분리하면, 특정 환경에서의 빌드가 다른 환경에 종속되지 않으므로 안정적입니다.
  • 서로 다른 환경 관리: 다양한 자바 바이트 코드를 생성하는 빌드 도구가 사용되므로, 빌드와 실행 사이에 명확한 경계를 두는 것이 필요합니다.

이러한 특성 때문에, Spring Boot는 종종 코드 수정 후 로컬 환경에서 빌드하고, 그 결과물을 Docker 이미지에 포함시켜 배포하는 방식으로 진행됩니다.

참고 자료

Spring Boot와 Docker에 관한 더 자세한 이유와 비교를 아래 URL에서 확인하실 수 있습니다:
- 도커 이미지 생성 및 소스 빌드에 관한 질문입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

김태환님의 프로필 이미지
김태환

작성한 질문수

질문하기