찾다
운영 및 유지보수DockerDocker에서 다단계 빌드를 사용하여 더 작고 안전한 이미지를 만드는 방법은 무엇입니까?

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으로 문의하세요.
Docker 's Architecture : 용기 및 이미지 이해Docker 's Architecture : 용기 및 이미지 이해May 08, 2025 am 12:17 AM

Docker Architecture의 핵심 개념은 컨테이너 및 거울입니다. 1. 거울은 응용 프로그램 및 종속성을 포함한 컨테이너의 청사진입니다. 2. 컨테이너는 이미지 인스턴스를 실행 중이며 이미지를 기반으로 작성됩니다. 3. 거울은 다중 읽기 전용 레이어로 구성되며 컨테이너가 실행 중일 때 쓰기 가능한 층이 추가됩니다. 4. Linux 네임 스페이스 및 제어 그룹을 통해 리소스 격리 및 관리를 구현합니다.

Docker의 힘 : 컨테이너화가 설명되었습니다Docker의 힘 : 컨테이너화가 설명되었습니다May 07, 2025 am 12:07 AM

Docker는 컨테이너화 기술을 통한 응용 프로그램의 건설, 배포 및 운영을 단순화합니다. 1) Docker는 컨테이너 기술을 사용하여 응용 프로그램 및 종속성을 패키지하여 환경 간 일관성을 보장하는 오픈 소스 플랫폼입니다. 2) 거울과 용기는 Docker의 핵심입니다. 미러는 응용 프로그램의 실행 파악 패키지이며 컨테이너는 이미지의 실행 된 인스턴스입니다. 3) Docker의 기본 사용은 Nginx 서버를 실행하는 것과 같으며 Advanced 사용법은 DockerCompose를 사용하여 멀티 컨테이너 응용 프로그램을 관리하는 것과 같습니다. 4) 일반적인 오류에는 이미지 다운로드 실패 및 컨테이너 스타트 업 실패가 포함되며 디버깅 기술은 로그보기 및 포트 점검이 포함됩니다. 5) 성능 최적화 및 모범 사례에는 미러 최적화, 자원 관리 및 보안 개선이 포함됩니다.

Kubernetes 및 Docker : 컨테이너화 된 앱을 배포하고 관리합니다Kubernetes 및 Docker : 컨테이너화 된 앱을 배포하고 관리합니다May 06, 2025 am 12:13 AM

Kubernetes 및 Docker를 사용하여 컨테이너화 된 애플리케이션을 배포하는 단계에는 다음이 포함됩니다. 1. Docker Image를 작성하고 Dockerfile을 사용하여 응용 프로그램 이미지를 정의하고 DockerHub로 누릅니다. 2. 응용 프로그램을 관리하고 노출시키기 위해 Kubernetes에서 배포 및 서비스를 작성하십시오. 3. HorizontalpodaUtoscaler를 사용하여 동적 스케일링을 달성하십시오. 4. Kubectl 명령을 통해 일반적인 문제를 디버그하십시오. 5. 성능을 최적화하고 리소스 제한 및 요청을 정의하며 Helm을 사용하여 구성을 관리합니다.

Docker : 컨테이너화 기술 소개Docker : 컨테이너화 기술 소개May 05, 2025 am 12:11 AM

Docker는 애플리케이션을 개발, 포장 및 실행하는 오픈 소스 플랫폼으로, 컨테이너화 기술을 통해 다양한 환경에서 응용 프로그램의 일관성을 해결합니다. 1. 이미지 구축 : Dockerfile을 통해 응용 프로그램 환경 및 종속성을 정의하고 DockerBuild 명령을 사용하여 빌드하십시오. 2. 컨테이너 실행 : DockErrun 명령을 사용하여 거울에서 컨테이너를 시작하십시오. 3. 컨테이너 관리 : Dockerps, Dockerstop, DockErrm 및 기타 명령을 통해 컨테이너 수명주기 관리.

Docker 및 Linux : 휴대용 응용 프로그램 구축Docker 및 Linux : 휴대용 응용 프로그램 구축May 03, 2025 am 12:17 AM

Docker 및 Linux로 휴대용 응용 프로그램을 구축하는 방법은 무엇입니까? 먼저 DockerFile을 사용하여 응용 프로그램을 컨테이너화 한 다음 Linux 환경에서 컨테이너를 관리하고 배포하십시오. 1) dockerfile을 작성하고 응용 프로그램과 그 종속성을 거울에 포장하십시오. 2) DockerBuild 및 Dockerrun 명령을 사용하여 Linux에 컨테이너를 빌드 및 실행하십시오. 3) DockerCompose를 통해 다중 윤곽 응용 프로그램을 관리하고 서비스 종속성을 정의합니다. 4) 이미지 크기 및 리소스 구성을 최적화하고 보안을 향상 시키며 애플리케이션 성능 및 휴대 성을 향상시킵니다.

Docker and Kubernetes : 컨테이너 오케스트레이션의 힘Docker and Kubernetes : 컨테이너 오케스트레이션의 힘May 02, 2025 am 12:06 AM

Docker와 Kubernetes는 컨테이너 오케스트레이션을 통해 응용 프로그램 배치 및 관리 효율성을 향상시킵니다. 1. Docker는 DockerFile을 통해 이미지를 빌드하고 컨테이너를 실행하여 응용 프로그램 일관성을 보장합니다. 2. Kubernetes는 POD, 배포 및 서비스를 통해 컨테이너를 관리하여 자동 배포 및 확장을 달성합니다.

Docker vs. Kubernetes : 주요 차이점과 시너지Docker vs. Kubernetes : 주요 차이점과 시너지May 01, 2025 am 12:09 AM

Docker와 Kubernetes는 컨테이너화 및 오케스트레이션의 리더입니다. Docker는 컨테이너 수명주기 관리에 중점을두고 소규모 프로젝트에 적합합니다. Kubernetes는 컨테이너 오케스트레이션에 능숙하며 대규모 생산 환경에 적합합니다. 이 둘의 조합은 개발 및 배포 효율성을 향상시킬 수 있습니다.

Docker and Linux : 완벽한 파트너십Docker and Linux : 완벽한 파트너십Apr 30, 2025 am 12:02 AM

Docker와 Linux는 응용 프로그램의 개발 및 배포를 단순화 할 수 있기 때문에 완벽하게 일치합니다. 1) Docker는 Linux의 네임 스페이스 및 CGroup을 사용하여 컨테이너 격리 및 리소스 관리를 구현합니다. 2) Docker 컨테이너는 가상 머신보다 효율적이며 스타트 업 속도가 빠르며 미러링 된 계층 구조는 구축 및 배포가 쉽습니다. 3) Linux에서 Docker의 설치 및 사용은 매우 간단하며 몇 가지 명령 만 있습니다. 4) DockerCompose를 통해 멀티 컨테이너 응용 프로그램을 쉽게 관리하고 배포 할 수 있습니다.

See all articles

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.