빠른 시작: 빌드

이 페이지에서는 Cloud Build를 사용하여 Docker 이미지를 빌드하고 Artifact Registry에 이미지를 푸시하는 방법을 설명합니다. Artifact Registry는 비공개 패키지 및 Docker 컨테이너 이미지를 관리하기 위한 단일 위치를 제공합니다.

먼저 Docker 구성 파일인 Dockerfile을 사용하여 이미지를 빌드하고 Cloud Build 구성 파일을 사용하여 동일한 이미지를 빌드합니다.

시작하기 전에

  1. Google 계정으로 로그인합니다.

    아직 계정이 없으면 새 계정을 등록하세요.

  2. Google Cloud Console의 프로젝트 선택기 페이지에서 Google Cloud 프로젝트를 선택하거나 만듭니다.

    프로젝트 선택기 페이지로 이동

  3. Cloud 프로젝트에 결제가 사용 설정되어 있는지 확인합니다. 프로젝트에 결제가 사용 설정되어 있는지 확인하는 방법을 알아보세요.

  4. Cloud Build, Artifact Registry API를 사용 설정합니다.

    API 사용 설정

  5. Cloud SDK 설치 및 초기화

소스 파일 준비

컨테이너 이미지로 패키징하려면 샘플 소스 코드가 필요합니다. 이 섹션에서는 간단한 셸 스크립트와 Dockerfile을 만듭니다. Dockerfile은 Docker로 이미지를 빌드하기 위한 지침이 포함된 텍스트 문서입니다.

  1. 터미널 창을 엽니다.

  2. quickstart-docker라는 이름의 새 디렉터리를 만들고 디렉터리로 이동합니다.

    mkdir quickstart-docker
    cd quickstart-docker
    
  3. 다음 콘텐츠로 quickstart.sh라는 파일을 만듭니다.

    #!/bin/sh
    echo "Hello, world! The time is $(date)."
    
  4. 다음 콘텐츠로 Dockerfile라는 파일을 만듭니다.

    FROM alpine
    COPY quickstart.sh /
    CMD ["/quickstart.sh"]
    
  5. 다음 명령어를 실행하여 quickstart.sh를 실행 가능하게 만듭니다.

    chmod +x quickstart.sh
    

Artifact Registry에서 Docker 저장소 만들기

  1. us-central1 위치에 'Docker 저장소' 설명과 함께 quickstart-docker-repo라는 새 Docker 저장소를 만드세요.

    gcloud artifacts repositories create quickstart-docker-repo --repository-format=docker \
        --location=us-central1 --description="Docker repository"
    
  2. 저장소가 만들어졌는지 확인합니다.

    gcloud artifacts repositories list
    

Dockerfile을 사용하여 빌드

Cloud Build에서는 Dockerfile을 사용하여 Docker 이미지를 빌드할 수 있습니다. 별도의 Cloud Build 구성 파일이 필요하지 않습니다.

Dockerfile을 사용하여 빌드하려면 다음 안내를 따르세요.

  1. 다음 명령어를 실행하여 Cloud 프로젝트 ID를 가져옵니다.

    gcloud config get-value project
    
  2. quickstart.shDockerfile이 포함된 디렉터리에서 다음 명령어를 실행합니다. 여기서 project-id는 클라우드 프로젝트 ID입니다.

    gcloud builds submit --tag us-central1-docker.pkg.dev/project-id/quickstart-docker-repo/quickstart-image:tag1
    

빌드가 완료되면 다음과 비슷한 출력이 표시됩니다.

DONE
------------------------------------------------------------------------------------------------------------------------------------
ID                                    CREATE_TIME                DURATION  SOURCE   IMAGES     STATUS
545cb89c-f7a4-4652-8f63-579ac974be2e  2020-11-05T18:16:04+00:00  16S       gs://gcb-docs-project_cloudbuild/source/1604600163.528729-b70741b0f2d0449d8635aa22893258fe.tgz  us-central1-docker.pkg.dev/gcb-docs-project/quickstart-docker-repo/quickstart-image:tag1  SUCCESS

Dockerfile을 사용하여 quickstart-image라는 Docker 이미지를 빌드하고 Artifact Registry에 푸시했습니다.

빌드 구성 파일을 사용하여 빌드

이 섹션에서는 Cloud Build 구성 파일을 사용하여 위와 동일한 Docker 이미지를 빌드합니다. 빌드 구성 파일은 사양에 따라 작업을 수행하도록 Cloud Build에 지시합니다.

  1. quickstart.shDockerfile이 포함된 동일한 디렉터리에서 다음 내용으로 cloudbuild.yaml이라는 파일을 만듭니다. 이 파일은 빌드 구성 파일입니다. 빌드 시 Cloud Build는 자동으로 $PROJECT_ID를 프로젝트 ID로 바꿉니다.

    steps:
    - name: 'gcr.io/cloud-builders/docker'
      args: [ 'build', '-t', 'us-central1-docker.pkg.dev/$PROJECT_ID/quickstart-docker-repo/quickstart-image:tag1', '.' ]
    images:
    - 'us-central1-docker.pkg.dev/$PROJECT_ID/quickstart-docker-repo/quickstart-image:tag1'
    
  2. 다음 명령어를 실행하여 빌드를 시작합니다.

    gcloud builds submit --config cloudbuild.yaml
    

빌드가 완료되면 다음과 비슷한 출력이 표시됩니다.

DONE
------------------------------------------------------------------------------------------------------------------------------------
ID                                    CREATE_TIME                DURATION  SOURCE          IMAGES          STATUS
046ddd31-3670-4771-9336-8919e7098b11  2020-11-05T18:24:02+00:00  15S       gs://gcb-docs-project_cloudbuild/source/1604600641.576884-8153be22c94d438aa86c78abf11403eb.tgz  us-central1-docker.pkg.dev/gcb-docs-project/quickstart-docker-repo/quickstart-image:tag1  SUCCESS

빌드 구성 파일을 사용하여 quickstart-image를 빌드하고 Artifact Registry에 푸시했습니다.

빌드 세부정보 보기

  1. Google Cloud Console에서 Cloud Build 페이지를 엽니다.

    Cloud Build 페이지 열기

  2. 프로젝트를 선택하고 열기를 클릭합니다.

    빌드 기록 페이지가 표시됩니다.

    빌드 기록 페이지 스크린샷

  3. 특정 빌드를 클릭합니다.

    빌드 세부정보 페이지가 표시됩니다.

  4. 빌드의 아티팩트를 보려면 빌드 요약에서 빌드 아티팩트를 클릭합니다.

    다음과 비슷한 출력이 표시됩니다.

    빌드 아티팩트 스크린샷

    이 페이지에서 Artifact Registry의 빌드 로그를 다운로드하고 이미지 세부정보를 볼 수 있습니다.

정리

이 빠른 시작에서 사용한 리소스의 비용이 Google Cloud 계정에 청구되지 않도록 하려면 다음 단계를 따르세요.

  1. Google Cloud Console에서 Artifact Registry 페이지를 엽니다.

    Artifact Registry 페이지 열기

  2. 프로젝트를 선택하고 열기를 클릭합니다.

  3. quickstart-docker-repo를 선택합니다.

  4. 삭제를 클릭합니다.

이제 이 빠른 시작의 일부로 만든 이미지가 저장소가 삭제되었습니다.

빠른 시작을 완료하셨습니다.

다음 단계