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

Donggun Jang님의 프로필 이미지
Donggun Jang

작성한 질문수

개발자를 위한 쉬운 도커

3Tier 아키텍처 구성

npm run ci 캐싱 관련 질문입니다.

해결된 질문

작성

·

49

1

안녕하세요

도커가 npm 패키지 변경내역을 어떤식으로 알 수 있는건지 원리가 궁금해서 질문드립니다.

도커 자체에서 package.json과 package-lock.json파일이 패키지에 관련된 파일이란 것을 인식해서, 해당 파일들의 내용이 변경여부에 따라 캐싱이미지를 사용할지 말지 결정하는건가요?

감사합니다.

답변 2

0

데브위키님의 프로필 이미지
데브위키
지식공유자

Donggun Jang님 안녕하세요. 데브위키입니다.

프론트엔드의 도커파일에는 아래와 같이 COPY 지시어가 있습니다.

COPY package.json .
COPY package-lock.json .

package.json과 package-lock.json이 패키지 관련 파일이라는것은 도커가 알 수는 없지만,

각 레이어마다 파일의 내용이 포함된 해시 값을 가지고 있습니다.

이전 빌드와 비교했을 때 파일이 변경되었다는 것은 알 수 있는 것이죠.

그래서 이전 빌드의 파일 해시 값과 현재 빌드의 파일 해시 값을 비교해 보았을 때, 해시 값이 다르면 캐시된 레이어를 사용하지 않고 새로운 레이어를 사용하게 됩니다.

 

강의 들으시면서 더 궁금하신 부분이 있으면 편하게 질문해주세요!

 

0

안녕하세요, 인프런 AI 인턴입니다. Donggun Jang님.

도커에서 npm install과 같은 명령어를 사용하는 경우, 캐시를 활용하여 효율적으로 이미지를 빌드할 수 있는 방법이 많이 논의되고 있습니다. 도커는 각 레이어의 변경 사항을 감지하여 레이어를 재사용할지 새로 생성할지를 결정합니다. 여기에서 중요한 점은 Dockerfile의 레이어 순서입니다.

  • package.json 및 package-lock.json 파일 변경: 도커는 파일이 변경되었는지를 판단하여, 변경된 경우 해당 명령어 레이어 이후 모든 레이어를 새로 생성합니다. RUN npm install 문을 포함한 레이어는 이 두 파일이 변경될 때마다 새롭게 캐시가 업데이트됩니다.

  • 도커의 캐싱 메커니즘: 도커는 기본적으로 파일의 변경사항, 명령어와 그 결과를 기반으로 캐시를 활용합니다. 따라서 COPY package.json .의 결과가 새로운 파일로 변하면, 그 다음의 RUN 명령어가 새로 실행됩니다.

보다 상세한 작동 원리와 유용한 팁은 아래 링크에서 확인하실 수 있습니다:

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

Donggun Jang님의 프로필 이미지
Donggun Jang

작성한 질문수

질문하기