시작하기 전에
- 실습에서는 정해진 기간 동안 Google Cloud 프로젝트와 리소스를 만듭니다.
- 실습에는 시간 제한이 있으며 일시중지 기능이 없습니다. 실습을 종료하면 처음부터 다시 시작해야 합니다.
- 화면 왼쪽 상단에서 실습 시작을 클릭하여 시작합니다.
최근에 Google Cloud를 주 클라우드 서비스 제공업체(CSP)로 사용하는 IT 기업에 클라우드 개발자로 채용되었다고 가정해 보겠습니다. 여러분은 서버리스, 스테이트리스(Stateless) 웹 애플리케이션을 클라우드에 빌드하라는 지시를 받았습니다. 이에 따라 Google Cloud에서 제공하는 Cloud Run 서비스를 도입해야 합니다. 이때 몇 가지 고려해야 할 사항이 있습니다.
여러분은 이전 직장에서 AWS를 사용한 경험이 있으므로 AWS Fargate가 컨테이너화된 환경을 서버리스 방식으로 프로비저닝한다는 점을 알고 있습니다. AWS Fargate는 컨테이너 출시, 확장, 모니터링 작업을 처리하므로 개발자는 애플리케이션 코드에 집중하여 컨테이너화된 애플리케이션을 쉽게 배포, 관리, 확장할 수 있습니다. AWS Fargate를 사용하면 Amazon Elastic Container Service(Amazon ECS) 또는 Amazon Elastic Kubernetes Service(Amazon EKS)를 위한 컨테이너를 배포할 수도 있습니다. 즉 개발자는 필요에 따라 가장 적합한 조정 옵션을 선택할 수 있습니다.
AWS Fargate 기반의 컨테이너화된 서버리스 애플리케이션은 다음 다이어그램과 같습니다.
이제 Google Cloud에서 애플리케이션을 배포하는 방법을 살펴보겠습니다.
Cloud Run은 HTTP 요청으로 호출 가능한 스테이트리스(Stateless) 컨테이너를 실행하는 관리형 컴퓨팅 플랫폼입니다. Cloud Run은 서버리스이므로 인프라 관리가 필요 없습니다. 따라서 개발자가 본연의 업무인 애플리케이션 개발에 집중할 수 있습니다.
Cloud Run은 Knative 기반으로 빌드되어 컨테이너 실행 환경을 선택할 수 있습니다. Cloud Run을 사용하는 완전 관리형 환경 또는 GKE에서 Cloud Run을 사용하는 Google Kubernetes Engine 클러스터 중에서 선택하면 됩니다.
이 실습의 목적은 컨테이너화된 간단한 애플리케이션 이미지를 빌드하여 Cloud Run에 배포하는 방법을 배우는 것입니다.
이 실습에서는 다음을 수행하는 방법에 대해 알아봅니다.
각 실습에서는 정해진 기간 동안 새 Google Cloud 프로젝트와 리소스 집합이 무료로 제공됩니다.
시크릿 창을 사용하여 Qwiklabs에 로그인합니다.
실습 사용 가능 시간(예: 1:15:00)을 참고하여 해당 시간 내에 완료합니다.
일시중지 기능은 없습니다. 필요한 경우 다시 시작할 수 있지만 처음부터 시작해야 합니다.
준비가 되면 실습 시작을 클릭합니다.
실습 사용자 인증 정보(사용자 이름 및 비밀번호)를 기록해 두세요. Google Cloud Console에 로그인합니다.
Google Console 열기를 클릭합니다.
다른 계정 사용을 클릭한 다음, 안내 메시지에 이 실습에 대한 사용자 인증 정보를 복사하여 붙여넣습니다.
다른 사용자 인증 정보를 사용하는 경우 오류가 발생하거나 요금이 부과됩니다.
약관에 동의하고 리소스 복구 페이지를 건너뜁니다.
실습 시작 버튼을 클릭합니다. 실습 비용을 결제해야 하는 경우 결제 수단을 선택할 수 있는 팝업이 열립니다. 왼쪽에 있는 패널에서 이 실습에 사용해야 하는 임시 사용자 인증 정보를 확인할 수 있습니다.
사용자 이름을 복사한 다음 Google 콘솔 열기를 클릭합니다. 실습에서 리소스가 실행되며 계정 선택 페이지를 표시하는 다른 탭이 열립니다.
계정 선택 페이지에서 다른 계정 사용을 클릭합니다. 로그인 페이지가 열립니다.
연결 세부정보 패널에서 복사한 사용자 이름을 붙여넣습니다. 그런 다음 비밀번호를 복사하여 붙여넣습니다.
잠시 후 Cloud 콘솔이 이 탭에서 열립니다.
Google Cloud Shell은 다양한 개발 도구가 탑재된 가상 머신으로, 5GB의 영구 홈 디렉터리를 제공하며 Google Cloud에서 실행됩니다.
Google Cloud Shell을 사용하면 명령줄을 통해 Google Cloud 리소스에 액세스할 수 있습니다.
Cloud 콘솔의 오른쪽 상단 툴바에서 'Cloud Shell 열기' 버튼을 클릭합니다.
계속을 클릭합니다.
환경을 프로비저닝하고 연결하는 데 몇 분 정도 소요됩니다. 연결되면 사용자가 미리 인증되어 프로젝트가 PROJECT_ID로 설정됩니다. 예:
gcloud는 Google Cloud의 명령줄 도구입니다. Cloud Shell에 사전 설치되어 있으며 명령줄 자동 완성을 지원합니다.
출력:
출력 예시:
출력:
출력 예시:
다음은 이 실습의 지침 또는 코드 블록에 등장할 수 있는 몇 가지 기본 Linux 명령어입니다.
| 명령어 --> | 작업 | . | 명령어 --> | 작업 |
|---|---|---|---|---|
| mkdir(디렉터리 생성) | 새 폴더를 만듭니다. | . | cd(디렉터리 변경) | 다른 폴더로 위치를 변경합니다. |
| ls(항목 나열) | 디렉터리 내 파일 및 폴더를 나열합니다. | . | cat(연결) | 편집기를 사용하지 않고 파일 콘텐츠를 읽어 옵니다. |
| apt-get update | 패키지 관리자 라이브러리를 업데이트합니다. | . | ping | 호스트의 연결 가능성을 테스트하기 위해 신호를 보냅니다. |
| mv(이동) | 파일을 이동합니다. | . | cp(복사) | 파일 사본을 만듭니다. |
| pwd(현재 작업 디렉터리) | 현재 위치를 반환합니다. | . | sudo(수퍼유저 권한 실행) | 상위 관리자 권한을 부여합니다. |
이 작업에서는 HTTP 요청에 응답하는 간단한 표현 기반 NodeJS 애플리케이션을 빌드합니다.
helloworld인 새 디렉터리를 만든 다음, 이 디렉터리로 뷰를 이동합니다.그런 다음 파일을 만들고 편집합니다. 파일을 편집하려면 vi, emac, nano를 사용하거나 Cloud Shell에서 편집기 열기 버튼을 클릭하여 Cloud Shell 코드 편집기를 사용합니다.
package.json 파일을 만든 다음, 아래의 내용을 추가합니다.
가장 중요한 점은 위의 파일에 Express 웹 애플리케이션 프레임워크에 대한 종속 항목과 시작 스크립트 명령어가 포함되어 있다는 점입니다.
Ctrl+X를 누른 다음 Y를 눌러 package.json 파일을 저장합니다.
이제 동일한 디렉터리에서 index.js 파일을 만든 후 이 파일에 다음을 복사하여 붙여넣습니다.
이 코드는 PORT 환경 변수로 정의한 포트를 리슨하는 기본 웹 서버를 생성합니다. 앱이 완성되었으며 이제 컨테이너화하여 Container Registry에 업로드할 준비가 되었습니다.
index.js 파일을 저장합니다.Dockerfile이라는 새 파일을 만든 후 이 파일에 다음 콘텐츠를 추가합니다.Ctrl+X를 누른 다음 Y를 눌러 Dockerfile 파일을 저장합니다.
Dockerfile이 포함되어 있는 디렉터리에서 다음 명령어를 실행하여 Cloud Build로 컨테이너 이미지를 빌드합니다. (참고로 명령어의 $GOOGLE_CLOUD_PROJECT 환경 변수에는 실습 프로젝트 ID가 포함됩니다.)
Cloud Build는 GCP에서 빌드를 실행하는 서비스입니다. Cloud Build는 일련의 빌드 단계를 실행합니다. 여기에서 각 빌드 단계는 Docker 컨테이너에서 실행되어 애플리케이션 컨테이너(또는 기타 아티팩트)를 생성하며 이를 Cloud Registry로 푸시합니다. 이러한 모든 과정이 하나의 명령어로 이루어집니다.
레지스트리로 푸시된 후에는 이미지 이름이 포함된 SUCCESS 메시지가 표시됩니다(gcr.io/[PROJECT-ID]/helloworld). 이미지는 Artifact Registry에 저장되며 원하는 경우 다시 사용할 수 있습니다.
docker 명령어를 사용하여 시작합니다.그러면 브라우저 창이 열리고 'Hello World!' 메시지가 표시됩니다. 간단히 curl localhost:8080을 사용해도 됩니다.
docker 명령어로 원격 컨테이너 이미지를 가져올 수 없는 경우에는 gcloud auth configure-docker를 실행해 보세요.
위 명령어의 allow-unauthenticated 플래그를 사용하면 내 서비스가 공개적으로 액세스 가능하게 됩니다.
service name을 확인합니다.그런 다음 배포가 완료될 때까지 잠시 기다립니다.
성공하면 명령줄에 다음과 같은 서비스 URL이 표시됩니다.
이제 브라우저 창에서 서비스 URL을 열어 배포된 컨테이너로 이동할 수 있습니다.
수고하셨습니다. 컨테이너 이미지로 패키징된 애플리케이션을 Cloud Run에 배포했습니다. Cloud Run은 수신된 요청을 처리하기 위해 컨테이너 이미지를 자동 및 수평 확장한 다음 수요가 감소하면 축소합니다. 자체 환경에서는 요청 처리 도중 소비한 CPU, 메모리, 네트워킹에 대해서만 비용을 지불합니다.
이 실습에서는 gcloud 명령줄을 사용했습니다. Cloud Run은 Cloud 콘솔을 통해서도 사용할 수 있습니다.
helloworld 서비스가 표시됩니다.Cloud Run에서는 서비스를 사용하지 않을 때 비용이 청구되지 않지만 빌드된 컨테이너 이미지를 저장하는 데 요금이 부과될 수 있습니다.
helloworld 이미지를 삭제할 수 있습니다.메시지가 표시되면 Y를 입력하고 Enter 키를 누릅니다.
Cloud Run 서비스를 삭제하려면 다음 명령어를 사용합니다.
Y를 입력하고 Enter 키를 누릅니다.실습을 완료했습니다.
Google Cloud Run과 AWS Fargate는 모두 개발자가 확장 가능하고 비용 효율적인 방식으로 컨테이너화된 애플리케이션을 실행할 수 있는 서버리스 컴퓨팅 서비스입니다. 그러나 이 두 서비스 사이에는 몇 가지 차이점이 있습니다.
몇 가지 주요 유사점과 차이점은 다음과 같습니다.
유사점:
차이점:
실습을 완료하면 실습 종료를 클릭합니다. Google Cloud Skills Boost에서 사용된 리소스를 자동으로 삭제하고 계정을 지웁니다.
실습 경험을 평가할 수 있습니다. 해당하는 별표 수를 선택하고 의견을 입력한 후 제출을 클릭합니다.
별점의 의미는 다음과 같습니다.
의견을 제공하고 싶지 않다면 대화상자를 닫으면 됩니다.
의견이나 제안 또는 수정할 사항이 있다면 지원 탭을 사용하세요.
Copyright 2020 Google LLC All rights reserved. Google 및 Google 로고는 Google LLC의 상표입니다. 기타 모든 회사명 및 제품명은 해당 업체의 상표일 수 있습니다.
현재 이 콘텐츠를 이용할 수 없습니다
이용할 수 있게 되면 이메일로 알려드리겠습니다.
감사합니다
이용할 수 있게 되면 이메일로 알려드리겠습니다.
한 번에 실습 1개만 가능
모든 기존 실습을 종료하고 이 실습을 시작할지 확인하세요.