목차
Docker에서 다단계 빌드를 사용하여 더 작고 안전한 이미지를 만드는 방법은 무엇입니까?
다단계 Docker 빌드에서 코드를 구성하기위한 모범 사례는 무엇입니까?
다단 단계 Docker 빌드에서 캐싱을 최적화하여 빌드 시간을 개선하려면 어떻게해야합니까?
Docker Build가 단일 단계 빌드에 비해 어떤 보안 혜택을 제공합니까?
운영 및 유지보수 Docker Docker에서 다단계 빌드를 사용하여 더 작고 안전한 이미지를 만드는 방법은 무엇입니까?

Docker에서 다단계 빌드를 사용하여 더 작고 안전한 이미지를 만드는 방법은 무엇입니까?

Mar 14, 2025 pm 02:15 PM

Docker에서 다단계 빌드를 사용하여 더 작고 안전한 이미지를 만드는 방법은 무엇입니까?

Docker의 다단계 빌드는 Dockerfile의 여러 FROM 을 사용할 수있는 기능입니다. 각각 FROM 명령문은 빌드 프로세스의 새로운 단계를 시작할 수 있으며 한 단계에서 다른 단계에서 아티팩트를 복사 할 수 있습니다. 이 방법은 런타임 환경에서 빌드 환경을 분리하여 작고 안전한 Docker 이미지를 작성하는 데 특히 유용합니다.

다단계 빌드를 사용하여이를 달성하는 방법은 다음과 같습니다.

  1. 빌드 스테이지 정의 : 응용 프로그램을 컴파일하거나 아티팩트를 준비하는 빌드 스테이지를 정의하여 시작하십시오. 예를 들어, golang 이미지를 사용하여 Go 응용 프로그램을 컴파일 할 수 있습니다.

     <code class="Dockerfile">FROM golang:1.16 as builder WORKDIR /app COPY . . RUN go build -o myapp</code>
    로그인 후 복사
  2. 런타임 단계 정의 : 빌드 스테이지 후에 최소 기본 이미지로 런타임 단계를 정의하십시오. 빌드 단계에서 필요한 아티팩트만이 런타임 단계로 복사하십시오.

     <code class="Dockerfile">FROM alpine:3.14 COPY --from=builder /app/myapp /myapp CMD ["/myapp"]</code>
    로그인 후 복사

다단계 빌드를 사용하면 응용 프로그램을 실행하는 데 필요한 것만 포함 된 최종 이미지로 끝납니다. 이는 건물에 사용되는 이미지에 비해 상당히 작고 잠재적 인 취약점이 적습니다.

다단계 Docker 빌드에서 코드를 구성하기위한 모범 사례는 무엇입니까?

다단계 Docker 빌드에서 효과적으로 코드를 구성하면 Dockerfile의 효율성과 명확성을 크게 향상시킬 수 있습니다. 모범 사례는 다음과 같습니다.

  1. 별도의 관심사 : 다른 목적 (예 : 건물, 테스트 및 배포)을 위해 다른 단계를 사용하십시오. 이러한 우려의 분리로 인해 Dockerfile을 쉽게 이해하고 유지할 수 있습니다.

     <code class="Dockerfile"># Build stage FROM node:14 as builder WORKDIR /app COPY package*.json ./ RUN npm install COPY . . RUN npm run build # Test stage FROM node:14 as tester WORKDIR /app COPY --from=builder /app . RUN npm run test # Runtime stage FROM node:14-alpine WORKDIR /app COPY --from=builder /app/build /app/build CMD ["node", "app/build/index.js"]</code>
    로그인 후 복사
  2. 레이어 수를 최소화하십시오 : 이미지의 레이어 수를 줄이기 위해 가능한 한 실행 명령을 결합하십시오. 이 연습은 빌드 프로세스의 속도를 높일뿐만 아니라 결과 이미지를 더 작게 만듭니다.

     <code class="Dockerfile">RUN apt-get update && \ apt-get install -y some-package && \ rm -rf /var/lib/apt/lists/*</code>
    로그인 후 복사
  3. .dockerignore 사용 : .dockerignore 파일을 작성하여 불필요한 파일이 Docker 빌드 컨텍스트에 복사되는 것을 제외합니다. 이는 빌드 프로세스 속도를 높이고 이미지 크기를 줄입니다.
  4. 복사 작업 최적화 : 각 단계에 필요한 파일 만 복사하십시오. 예를 들어, node.js 응용 프로그램의 빌드 스테이지에서 package.json 먼저 복사하고 npm install 실행 한 다음 나머지 응용 프로그램을 복사 할 수 있습니다.
  5. 명명 된 단계 사용 : Dockerfile을 쉽게 읽고 유지할 수 있도록 단계에 의미있는 이름을 부여하십시오.

다단 단계 Docker 빌드에서 캐싱을 최적화하여 빌드 시간을 개선하려면 어떻게해야합니까?

다단계 Docker 빌드에서 캐싱을 최적화하면 빌드 시간을 크게 줄일 수 있습니다. 다음은이를 달성하기위한 몇 가지 전략입니다.

  1. 운영 순서 : Dockerfile의 끝을 향해 자주 변경되는 명령을 배치합니다. Docker는 Dockerfile의 시작 부분에서 레이어를 캐시하여 후속 빌드 속도를 높입니다.

     <code class="Dockerfile">FROM node:14 as builder WORKDIR /app COPY package*.json ./ RUN npm install COPY . . RUN npm run build</code>
    로그인 후 복사

    이 예에서는 npm install 응용 프로그램 코드보다 변경 될 가능성이 적으므로 COPY . . 명령.

  2. 다단계 빌드 사용 : 각 단계는 독립적으로 캐시 할 수 있습니다. 즉, 각 단계의 빌드 캐시를 활용하여 후속 빌드에서 시간을 절약 할 수 있습니다.
  3. Leverage BuildKit : Docker BuildKit은 개선 된 빌드 캐싱 메커니즘을 제공합니다. 환경 변수 DOCKER_BUILDKIT=1 설정하여 BuildKit을 활성화하고 새 RUN --mount 명령을 사용하여 캐시 디렉토리를 마운트하십시오.

     <code class="Dockerfile"># syntax=docker/dockerfile:experimental FROM golang:1.16 as builder RUN --mount=type=cache,target=/root/.cache/go-build \ go build -o myapp</code>
    로그인 후 복사
  4. Docker 빌드 컨텍스트를 최소화하십시오 . .dockerignore 파일을 사용하여 빌드 컨텍스트에서 불필요한 파일을 제외하십시오. 컨텍스트가 작은 것은 전송 데이터가 적고 더 빠른 빌드를 의미합니다.
  5. 특정 기본 이미지 사용 : 경량 및 안정적인베이스 이미지를 사용하여 빌드 중에 기본 레이어를 당기는 데 걸리는 시간을 줄입니다.

Docker Build가 단일 단계 빌드에 비해 어떤 보안 혜택을 제공합니까?

다단계 Docker Builds는 단일 단계 빌드와 비교하여 몇 가지 보안 이점을 제공합니다.

  1. 더 작은 이미지 크기 : 빌드 스테이지에서 런타임 단계로 필요한 아티팩트 만 복사하면 다단계 빌드는 훨씬 작은 최종 이미지를 초래합니다. 작은 이미지는 취약 할 수있는 구성 요소가 적기 때문에 공격 표면이 줄어 듭니다.
  2. 취약성 감소 : 최종 이미지에는 빌드 프로세스 중에 만 필요한 빌드 도구 또는 종속성이 포함되어 있지 않기 때문에 공격자가 해당 도구에서 취약점을 악용 할 수있는 기회는 적습니다.
  3. 빌드 및 런타임 환경의 분리 : 다단계 빌드를 사용하면 응용 프로그램을 구축하고 실행하는 데 다른 기본 이미지를 사용할 수 있습니다. 빌드 환경은 더 허용 될 수 있으며 컴파일 또는 포장에 필요한 도구를 포함시킬 수 있지만 런타임 환경은 보안을 위해 더 제한되고 최적화 될 수 있습니다.
  4. 더 쉽게 준수 : 더 작고 집중된 이미지는 취약성을 스캔하고 보안 정책을 준수 할 수 있으므로 안전한 환경을 더 쉽게 유지할 수 있습니다.
  5. 비밀 노출 제한 : 민감한 데이터 (빌드 중에 사용되는 API 키와 같은)는 최종 이미지에 포함될 필요가 없기 때문에 다단계 빌드는 비밀이 런타임 환경에 노출되는 것을 방지하는 데 도움이 될 수 있습니다.

다단계 빌드를 활용하면 Docker 이미지의 보안 자세를 크게 향상시키면서 크기와 성능을 최적화 할 수 있습니다.

위 내용은 Docker에서 다단계 빌드를 사용하여 더 작고 안전한 이미지를 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker 인터뷰 질문 : Ace Your DevOps 엔지니어링 인터뷰 Docker 인터뷰 질문 : Ace Your DevOps 엔지니어링 인터뷰 Apr 06, 2025 am 12:01 AM

Docker는 DevOps 엔지니어에게 필수 기술입니다. 1. Docker는 포장 애플리케이션 및 컨테이너에 대한 종속성을 통해 격리 및 휴대 성을 달성하는 오픈 소스 컨테이너화 플랫폼입니다. 2. Docker는 네임 스페이스, 제어 그룹 및 연합 파일 시스템과 함께 작동합니다. 3. 기본 사용에는 컨테이너 생성, 실행 및 관리가 포함됩니다. 4. 고급 사용법에는 DockerCompose를 사용하여 다중 컨테이너 응용 프로그램을 관리하는 것이 포함됩니다. 5. 일반적인 오류에는 컨테이너 고장, 포트 매핑 문제 및 데이터 지속성 문제가 포함됩니다. 디버깅 기술에는 로그보기, 컨테이너 입력 및 자세한 정보보기가 포함됩니다. 6. 성능 최적화 및 모범 사례에는 이미지 최적화, 리소스 제약 조건, 네트워크 최적화 및 Dockerfile 사용을위한 모범 사례가 포함됩니다.

Docker Security Hardening : 컨테이너를 취약성으로부터 보호합니다 Docker Security Hardening : 컨테이너를 취약성으로부터 보호합니다 Apr 05, 2025 am 12:08 AM

Docker Security 향상 방법에는 다음이 포함됩니다. 1.-캡 드롭 매개 변수를 사용하여 Linux 기능을 제한, 2. 읽기 전용 컨테이너 생성, 3. Selinux 태그 설정. 이러한 전략은 취약성 노출을 줄이고 공격자 기능을 제한함으로써 컨테이너를 보호합니다.

Docker Volumes : 컨테이너의 지속적인 데이터 관리 Docker Volumes : 컨테이너의 지속적인 데이터 관리 Apr 04, 2025 am 12:19 AM

DockErvolumes는 컨테이너가 다시 시작, 삭제 또는 마이그레이션 될 때 데이터가 안전하게 유지되도록합니다. 1. 볼륨 생성 : dockervolumecreatemydata. 2. 컨테이너를 실행하고 볼륨을 장착하십시오 : Dockerrun-it-vmydata :/app/dateubuntubash. 3. 고급 사용에는 데이터 공유 및 백업이 포함됩니다.

Linux와 함께 Docker 사용 : 포괄적 인 가이드 Linux와 함께 Docker 사용 : 포괄적 인 가이드 Apr 12, 2025 am 12:07 AM

Linux에서 Docker를 사용하면 개발 및 배포 효율성을 향상시킬 수 있습니다. 1. Docker 설치 : 스크립트를 사용하여 Ubuntu에 Docker를 설치하십시오. 2. 설치 확인 : Sudodockerrunhello-World를 실행하십시오. 3. 기본 사용 : Nginx 컨테이너 생성 Dockerrun-Namemy-Nginx-P8080 : 80-Dnginx. 4. 고급 사용 : DockerFile을 사용하여 사용자 정의 이미지를 만들고 빌드 및 실행하십시오. 5. 최적화 및 모범 사례 : 다단계 빌드 및 dockercompose를 사용하여 Dockerfiles를 작성하기위한 모범 사례를 따르십시오.

고급 Docker Networking : 마스터 링 브리지, 호스트 및 오버레이 네트워크 고급 Docker Networking : 마스터 링 브리지, 호스트 및 오버레이 네트워크 Apr 03, 2025 am 12:06 AM

Docker는 브리지 네트워크, 호스트 네트워크 및 오버레이 네트워크의 세 가지 주요 네트워크 모드를 제공합니다. 1. Bridge Network는 단일 호스트의 대기업 통신에 적합하며 가상 브리지를 통해 구현됩니다. 2. 호스트 네트워크는 고성능 네트워크가 필요한 시나리오에 적합하고 컨테이너는 호스트의 네트워크 스택을 직접 사용합니다. 3. 오버레이 네트워크는 다중 호스트 Dockerswarm 클러스터에 적합하며 가상 네트워크 계층을 통해 크로스 호스트 통신이 실현됩니다.

Docker Swarm : 확장 가능하고 탄력적 인 컨테이너 클러스터 구축 Docker Swarm : 확장 가능하고 탄력적 인 컨테이너 클러스터 구축 Apr 09, 2025 am 12:11 AM

Dockerswarm은 확장 가능한 고도로 컨테이너 클러스터를 구축하는 데 사용될 수 있습니다. 1) Dockers -Warminit을 사용하여 떼 클러스터를 초기화하십시오. 2) Swarm 클러스터에 가입하여 Dockers-Warmjoin-Token을 사용하십시오. 3) DockerserviceCreate-namemy-nginx-replicas3nginx를 사용하여 서비스를 만듭니다. 4) DockerstackDeploy-Cdocker-Compose.ymlmyapp을 사용하여 복잡한 서비스를 배포합니다.

도커 모니터링 : 메트릭 수집 및 컨테이너 건강 추적 도커 모니터링 : 메트릭 수집 및 컨테이너 건강 추적 Apr 10, 2025 am 09:39 AM

Docker 모니터링의 핵심은 주로 CPU 사용, 메모리 사용, 네트워크 트래픽 및 디스크 I/O와 같은 지표를 포함하여 컨테이너의 작동 데이터를 수집하고 분석하는 것입니다. Prometheus, Grafana 및 Cadvisor와 같은 도구를 사용하면 컨테이너의 포괄적 인 모니터링 및 성능 최적화를 달성 할 수 있습니다.

Dockerfile 모범 사례 : 효율적이고 최적화 된 이미지 작성 Dockerfile 모범 사례 : 효율적이고 최적화 된 이미지 작성 Apr 02, 2025 pm 02:07 PM

효율적이고 최적화 된 Docker 이미지를 만드는 방법은 무엇입니까? 1. 공식 또는 알파인 이미지와 같은 적절한 기본 이미지를 선택하십시오. 2. 지침 순서를 합리적으로 정리하고 Docker 캐시 메커니즘을 사용하십시오. 3. 다단 구조를 사용하여 이미지 크기를 줄입니다. 4. 미러 레이어 수를 최소화하고 실행 지침을 병합하십시오. 5. 불필요한 파일 공간을 피하기 위해 임시 파일을 정리하십시오.

See all articles