1. 개요
이 Codelab 시리즈 (사용자 주도형, 실무 가이드)는 개발자가 애플리케이션을 배포할 때 사용할 수 있는 다양한 옵션을 이해할 수 있도록 돕기 위한 것입니다. 이 Codelab에서는 Python으로 Google Cloud Translation API를 사용하고 로컬에서 실행하거나 Cloud 서버리스 컴퓨팅 플랫폼 (App Engine, Cloud Functions 또는 Cloud Run)에 배포하는 방법을 알아봅니다. 이 튜토리얼의 저장소에 있는 샘플 앱은 약간의 구성 변경만으로 8가지 방법으로 배포할 수 있습니다.
- 로컬 Flask 서버 (Python 2)
- 로컬 Flask 서버 (Python 3)
- App Engine (Python 2)
- App Engine (Python 3)
- Cloud Functions (Python 3)
- Cloud Run (Docker를 통한 Python 2)
- Cloud Run (Docker를 통한 Python 3)
- Cloud Run (Cloud Buildpacks를 통한 Python 3)
이 Codelab에서는 위의 굵은 글꼴로 표시된 플랫폼에 이 앱을 배포하는 방법을 중점적으로 다룹니다.
학습 목표
- Google Cloud API, 특히 Cloud Translation API (고급/v3) 사용
- 기본 웹 애플리케이션을 로컬에서 실행하거나 Cloud 서버리스 컴퓨팅 플랫폼에 배포합니다.
필요한 항목
- 활성 Cloud Billing 계정이 있는 Google Cloud 프로젝트
- 로컬에서 실행하도록 설치된 Flask 또는 클라우드 기반 배포를 위해 사용 설정된 Cloud 서버리스 컴퓨팅 플랫폼
- 기본 Python 기술
- 기본 운영체제 명령어에 대한 실무 지식
설문조사
본 가이드를 어떻게 사용하실 계획인가요?
귀하의 Python 사용 경험이 어떤지 평가해 주세요.
귀하의 Google Cloud 서비스 사용 경험을 평가해 주세요.
2. 설정 및 요건
자습형 환경 설정
- Google Cloud Console에 로그인하여 새 프로젝트를 만들거나 기존 프로젝트를 재사용합니다. 아직 Gmail이나 Google Workspace 계정이 없는 경우 계정을 만들어야 합니다.
- 프로젝트 이름은 이 프로젝트 참가자의 표시 이름입니다. 이는 Google API에서 사용하지 않는 문자열이며 언제든지 업데이트할 수 있습니다.
- 프로젝트 ID는 모든 Google Cloud 프로젝트에서 고유해야 하며, 변경할 수 없습니다(설정된 후에는 변경할 수 없음). Cloud Console은 고유한 문자열을 자동으로 생성합니다. 일반적으로 신경 쓰지 않아도 됩니다. 대부분의 Codelab에서는 프로젝트 ID를 참조해야 하며(일반적으로
PROJECT_ID
로 식별됨), 마음에 들지 않는 경우 임의로 다시 생성하거나 직접 지정해서 사용할 수 있는지 확인하세요. 프로젝트가 생성되면 프로젝트 ID가 '고정'됩니다. - 세 번째 값은 일부 API에서 사용하는 프로젝트 번호입니다. 이 세 가지 값에 대한 자세한 내용은 문서를 참조하세요.
- 다음으로 Cloud 리소스/API를 사용하려면 Cloud Console에서 결제를 사용 설정해야 합니다. 이 Codelab 실행에는 많은 비용이 들지 않습니다. 이 튜토리얼을 마친 후 비용이 결제되지 않도록 리소스를 종료하려면 Codelab의 끝에 있는 '삭제' 안내를 따르세요. Google Cloud 새 사용자에게는 미화 $300 상당의 무료 체험판 프로그램에 참여할 수 있는 자격이 부여됩니다.
3. Translation API 사용 설정
Cloud API 사용 설정
이 섹션에서는 일반적으로 Google API를 사용 설정하는 방법을 알아봅니다. 샘플 앱의 경우 Cloud Translation API, Cloud Run, Cloud Artifact Registry를 사용 설정합니다.
소개
애플리케이션에서 사용할 Google API에 관계없이 사용 설정되어야 합니다. 다음 예는 Cloud Vision API를 사용 설정하는 두 가지 방법을 보여줍니다. Cloud API 하나를 사용 설정하는 방법을 알아두면 프로세스가 비슷하므로 다른 API도 사용 설정할 수 있습니다.
옵션 1: Cloud Shell 또는 명령줄 인터페이스에서
Cloud 콘솔에서 API를 사용 설정하는 것이 더 일반적이지만 명령줄에서 모든 작업을 하는 것을 선호하는 개발자도 있습니다. 이렇게 하려면 API의 '서비스 이름'을 조회해야 합니다. URL처럼 보이지만 SERVICE_NAME
.googleapis.com
입니다. 지원되는 제품 차트에서 확인하거나 Google Discovery API를 사용하여 프로그래매틱 방식으로 쿼리할 수 있습니다.
이 정보를 바탕으로 Cloud Shell (또는 gcloud
명령줄 도구가 설치된 로컬 개발 환경)을 사용하여 다음과 같이 API를 사용 설정할 수 있습니다.
gcloud services enable SERVICE_NAME.googleapis.com
예를 들어 다음 명령어는 Cloud Vision API를 사용 설정합니다.
gcloud services enable vision.googleapis.com
이 명령어는 App Engine을 사용 설정합니다.
gcloud services enable appengine.googleapis.com
하나의 요청으로 여러 API를 사용 설정할 수도 있습니다. 예를 들어 다음 명령줄은 Cloud Run, Cloud Artifact Registry, Cloud Translation API를 사용 설정합니다.
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
옵션 2: Cloud 콘솔에서
API 관리자에서 Vision API를 사용 설정할 수도 있습니다. Cloud 콘솔에서 API 관리자로 이동하고 라이브러리를 선택합니다.
Cloud Vision API를 사용 설정하려면 검색창에 'vision'을 입력하면 지금까지 입력한 내용과 일치하는 항목이 표시됩니다.
사용 설정하려는 API를 선택하고 사용 설정을 클릭합니다.
비용
많은 Google API는 비용 없이 사용될 수 있지만 Google Cloud 제품 및 API는 무료가 아닙니다. Cloud API를 사용 설정하면 활성 결제 계정을 묻는 메시지가 표시될 수 있습니다. 하지만 일부 Google Cloud 제품에는 '항상 무료' 등급 (일일/월별)이 있으며, 이를 초과할 경우에만 결제 청구가 발생합니다. 그렇지 않으면 신용카드 (또는 지정된 결제 수단)에 청구되지 않습니다.
사용자는 API를 사용 설정하기 전에 API의 가격 책정 정보를 참고해야 합니다. 특히 무료 등급이 있는지, 있다면 어떤 등급인지 확인해야 합니다. Cloud Vision API를 사용 설정하는 경우 가격 책정 정보 페이지를 확인합니다. Cloud Vision에는 무료 할당량이 있으며, 1개월 내 총 사용량이 한도 내로 유지되는 한 비용이 발생하지 않습니다.
가격 및 무료 등급은 Google API마다 다릅니다. 예:
- Google Cloud/GCP: 각 제품은 청구 방식이 다르며 일반적으로 vCPU 주기, 스토리지 소비자, 메모리 사용량 또는 사용량 기반 요금제로 청구됩니다. 위의 무료 등급 정보를 참고하세요.
- Google 지도: API 모음을 제공하며 사용자에게 월$200 상당의 무료 크레딧을 제공합니다.
- Google Workspace (이전 명칭: G Suite) API: Workspace 월간 구독 요금에 포함된 무료 사용량 (최대 한도까지)을 제공하므로 Gmail, Google Drive, Calendar, Docs, Sheets, Slides API 사용에 대한 직접 청구가 없습니다.
각 Google 제품마다 결제 방식이 다르므로, API 문서에서 해당 정보를 확인해야 합니다.
요약
이제 일반적으로 Google API를 사용 설정하는 방법을 알게 되었습니다. API 관리자로 이동하여 Cloud Translation API, Cloud Run, Cloud Artifact Registry를 사용 설정합니다 (아직 사용 설정하지 않은 경우). 애플리케이션에서 사용하기 때문에 전자를 사용 설정합니다. Cloud Run 서비스를 시작하기 위해 배포되기 전에 컨테이너 이미지가 저장되는 위치이므로 후자를 사용 설정합니다. 따라서 이 이미지를 사용 설정해야 합니다. gcloud
도구로 모두 사용 설정하려면 터미널에서 다음 명령어를 대신 실행합니다.
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
월별 할당량은 전체 '항상 무료' 등급 요약 페이지에 표시되지 않지만 Translation API 가격 책정 페이지에 따르면 모든 사용자는 매월 고정된 양의 번역된 문자를 사용할 수 있습니다. 이 기준점 미만으로 유지하면 API에서 요금이 청구되지 않습니다. 다른 Google Cloud 관련 청구가 있는 경우 마지막의 '정리' 섹션에서 설명합니다.
4. 샘플 앱 코드 가져오기
저장소의 코드를 로컬에서 또는 Cloud Shell (git clone
명령어 사용)에서 클론하거나 다음 스크린샷과 같이 녹색 Code 버튼에서 ZIP 파일을 다운로드합니다.
이제 모든 준비가 완료되었습니다. 이 튜토리얼에서는 파일을 삭제하거나 변경해야 할 수 있으므로 폴더의 전체 사본을 만들어 두세요. 다른 배포를 수행하려면 원본을 복사하여 다시 시작하면 되므로 다시 클론하거나 다운로드할 필요가 없습니다.
5. 샘플 앱 둘러보기
샘플 앱은 사용자가 영어로 텍스트를 입력하고 스페인어로 해당 텍스트의 상응하는 번역을 받도록 프롬프트하는 간단한 Google 번역 파생입니다. 이제 main.py
파일을 열어 작동 방식을 확인해 보겠습니다. 라이선스에 관한 주석 처리된 줄을 생략하면 상단과 하단이 다음과 같이 표시됩니다.
from flask import Flask, render_template, request
import google.auth
from google.cloud import translate
app = Flask(__name__)
_, PROJECT_ID = google.auth.default()
TRANSLATE = translate.TranslationServiceClient()
PARENT = 'projects/{}'.format(PROJECT_ID)
SOURCE, TARGET = ('en', 'English'), ('es', 'Spanish')
# . . . [translate() function definition] . . .
if __name__ == '__main__':
import os
app.run(debug=True, threaded=True, host='0.0.0.0',
port=int(os.environ.get('PORT', 8080)))
- 가져오기를 통해 Flask 기능,
google.auth
모듈, Cloud Translation API 클라이언트 라이브러리가 가져옵니다. - 전역 변수는 Flask 앱, Cloud 프로젝트 ID, Translation API 클라이언트, Translation API 호출의 상위 '위치 경로', 출발어 및 대상 언어를 나타냅니다. 이 경우 영어 (
en
)와 스페인어 (es
)이지만 Cloud Translation API에서 지원하는 다른 언어 코드로 언제든지 변경할 수 있습니다. - 하단의 큰
if
블록은 이 앱을 로컬에서 실행하는 튜토리얼에서 사용됩니다. 이 블록은 Flask 개발 서버를 활용하여 앱을 제공합니다. 웹 서버가 컨테이너에 번들로 포함되지 않은 경우 Cloud Run 배포 튜토리얼에서도 이 섹션을 사용합니다. 컨테이너에서 서버 번들링을 사용 설정하라는 메시지가 표시되지만 이 메시지를 간과하면 앱 코드가 Flask 개발 서버를 사용하도록 대체됩니다. App Engine 또는 Cloud Functions는 소스 기반 플랫폼이므로 이 문제는 해당되지 않습니다. 즉, Google Cloud에서 기본 웹 서버를 제공하고 실행합니다.
마지막으로 main.py
의 중앙에는 애플리케이션의 핵심인 translate()
함수가 있습니다.
@app.route('/', methods=['GET', 'POST'])
def translate(gcf_request=None):
"""
main handler - show form and possibly previous translation
"""
# Flask Request object passed in for Cloud Functions
# (use gcf_request for GCF but flask.request otherwise)
local_request = gcf_request if gcf_request else request
# reset all variables (GET)
text = translated = None
# if there is data to process (POST)
if local_request.method == 'POST':
text = local_request.form['text']
data = {
'contents': [text],
'parent': PARENT,
'target_language_code': TARGET[0],
}
# handle older call for backwards-compatibility
try:
rsp = TRANSLATE.translate_text(request=data)
except TypeError:
rsp = TRANSLATE.translate_text(**data)
translated = rsp.translations[0].translated_text
# create context & render template
context = {
'orig': {'text': text, 'lc': SOURCE},
'trans': {'text': translated, 'lc': TARGET},
}
return render_template('index.html', **context)
기본 함수는 사용자 입력을 받아 Translation API를 호출하여 무거운 작업을 실행합니다. 구체적으로 살펴보겠습니다.
local_request
변수를 사용하여 Cloud Functions에서 요청이 오는지 확인합니다. Cloud Functions는 자체 Flask 요청 객체를 전송하지만, 다른 모든 함수 (로컬에서 실행하거나 App Engine 또는 Cloud Run에 배포)는 Flask에서 직접 요청 객체를 가져옵니다.- 양식의 기본 변수를 재설정합니다. POST 요청에는 이를 대체하는 데이터가 있으므로 이는 주로 GET 요청에 적용됩니다.
- POST인 경우 번역할 텍스트를 가져와 API 메타데이터 요구사항을 나타내는 JSON 구조를 만듭니다. 그런 다음 API를 호출하고 사용자가 이전 라이브러리를 사용하는 경우 이전 버전의 API로 대체합니다.
- 어쨌든 실제 결과 (POST) 또는 데이터 없음 (GET)을 템플릿 컨텍스트로 형식 지정하고 렌더링합니다.
애플리케이션의 시각적 부분은 템플릿 index.html
파일에 있습니다. 이전에 번역된 결과가 표시되고 (그렇지 않은 경우 빈 공간) 번역할 내용을 요청하는 양식이 표시됩니다.
<!doctype html>
<html><head><title>My Google Translate 1990s</title><body>
<h2>My Google Translate (1990s edition)</h2>
{% if trans['text'] %}
<h4>Previous translation</h4>
<li><b>Original</b>: {{ orig['text'] }} (<i>{{ orig['lc'][0] }}</i>)</li>
<li><b>Translated</b>: {{ trans['text'] }} (<i>{{ trans['lc'][0] }}</i>)</li>
{% endif %}
<h4>Enter <i>{{ orig['lc'][1] }}</i> text to translate to <i>{{ trans['lc'][1] }}</i>:</h4>
<form method="POST"><input name="text"><input type="submit"></form>
</body></html>
6. 서비스 배포
이제 다음 명령어를 실행하여 Cloud Run에 번역 서비스를 배포할 수 있습니다.
gcloud run deploy translate --source . --allow-unauthenticated --platform managed
출력은 다음과 같이 표시되며 다음 단계에 대한 메시지를 제공합니다.
$ gcloud run deploy translate --source . --allow-unauthenticated --platform managed Please specify a region: [1] asia-east1 [2] asia-east2 . . . (other regions) . . . [28] us-west4 [29] cancel Please enter your numeric choice: REGION_CHOICE To make this the default region, run `gcloud config set run/region REGION`. Deploying from source requires an Artifact Registry repository to store build artifacts. A repository named [cloud-run-source-deploy] in region [REGION] will be created. Do you want to continue (Y/n)? This command is equivalent to running "gcloud builds submit --pack image=[IMAGE] ." and "gcloud run deploy translate --image [IMAGE]" Building . . . and deploying container to Cloud Run service [translate] in project [PROJECT_ID] region [REGION] ✓ Building and deploying... Done. ✓ Creating Container Repository... ✓ Uploading sources... ✓ Building Container... Logs are available at [https://console.cloud.google.com/cloud-build/builds/60e1b 9bb-b991-4b4e-8d8a-HASH?project=PROJECT_NUMBER]. ✓ Creating Revision... ✓ Routing traffic... ✓ Setting IAM Policy... Done. Service [translate] revision [translate-00001-xyz] has been deployed and is serving 100 percent of traffic. Service URL: https://SVC_NAME-HASH-REG_ABBR.a.run.app
이제 앱을 전 세계에서 사용할 수 있으므로 배포 출력에 표시된 대로 프로젝트 ID가 포함된 URL에서 앱에 액세스할 수 있습니다.
뭔가를 번역해 보세요.
7. 결론
축하합니다. Cloud Translation API를 사용 설정하고, 필요한 사용자 인증 정보를 가져오고, 간단한 웹 앱을 Python 2 Cloud Run에 배포하는 방법을 알아봤습니다. 이 배포에 관한 자세한 내용은 저장소의 이 표를 참고하세요.
삭제
Cloud Translation API를 사용하면 매월 고정된 양의 번역 문자를 무료로 처리할 수 있습니다. App Engine에는 무료 할당량도 있으며 Cloud Functions 및 Cloud Run에도 동일하게 적용됩니다. 이 두 가지 중 하나를 초과하면 요금이 청구됩니다. 다음 Codelab을 계속할 계획이라면 앱을 종료하지 않아도 됩니다.
하지만 다음 튜토리얼로 이동할 준비가 되지 않았거나 방금 배포한 앱이 인터넷에서 감지될까 우려된다면 비용이 발생하지 않도록 App Engine 앱을 사용 중지하거나 Cloud Functions를 삭제하거나 Cloud Run 서비스를 사용 중지하세요. 다음 Codelab으로 이동할 준비가 되었으면 이를 다시 사용 설정하면 됩니다. 반면에 이 애플리케이션이나 다른 Codelab을 계속하지 않고 모든 것을 완전히 삭제하려면 프로젝트를 종료하면 됩니다.
또한 Google Cloud 서버리스 컴퓨팅 플랫폼에 배포하면 소규모 빌드 및 스토리지 비용이 발생합니다. Cloud Build에는 Cloud Storage와 마찬가지로 자체 무료 할당량이 있습니다. Cloud Build는 투명성을 높이기 위해 애플리케이션 이미지를 빌드한 후 Cloud Container Registry 또는 후속 버전인 Artifact Registry에 저장합니다. 이미지 저장소는 이미지를 서비스로 전송할 때의 네트워크 이그레스와 마찬가지로 할당량의 일부를 사용합니다. 하지만 이러한 무료 등급이 제공되지 않는 지역에 거주하는 경우 스토리지 사용량에 유의하여 잠재적인 비용을 최소화하세요.
8. 추가 리소스
다음 섹션에서는 이 튜토리얼을 완료하면서 얻은 지식을 보완할 수 있는 추가 읽을거리와 권장 연습문제를 확인할 수 있습니다.
추가 연구
이제 Translation API에 대해 어느 정도 경험을 했으므로 추가 연습을 통해 기술을 더욱 발전시켜 보겠습니다. 학습 과정을 계속하려면 샘플 앱을 수정하여 다음을 실행합니다.
- 로컬에서 실행하거나 Google Cloud 서버리스 컴퓨팅 플랫폼에 배포하기 위한 이 Codelab의 다른 모든 버전을 완료합니다 (저장소 리드미 참고).
- 다른 프로그래밍 언어를 사용하여 이 튜토리얼을 완료합니다.
- 다른 출발어 또는 도착어를 지원하도록 이 애플리케이션을 변경합니다.
- 텍스트를 두 개 이상의 언어로 번역할 수 있도록 이 애플리케이션을 업그레이드합니다. 지원되는 대상 언어의 풀다운이 표시되도록 템플릿 파일을 변경합니다.
자세히 알아보기
Google App Engine
- App Engine 홈페이지
- App Engine 문서
- Python 3 App Engine 빠른 시작
- App Engine의 기본 서비스 계정
- Python 2 App Engine (표준) 런타임
- Python 3 App Engine (표준) 런타임
- Python 2 및 3 App Engine (표준) 런타임의 차이점
- Python 2에서 3으로의 App Engine (표준) 마이그레이션 가이드
Google Cloud Functions
Google Cloud Run
Google Cloud Buildpacks, Container Registry, Artifact Registry
- Cloud Buildpacks 공지사항
- Cloud Buildpacks 저장소
- Cloud Artifact Registry 홈페이지
- Cloud Artifact Registry 문서
- Cloud Container Registry 홈페이지
- Cloud Container Registry 문서
Google Cloud Translation 및 Google ML Kit
- Cloud Translation 홈페이지
- Cloud Translation 문서
- Translation API 가격 책정 페이지
- 모든 Cloud AI/ML '구성 요소' API
- Google ML Kit (모바일용 Cloud AI/ML API 하위 집합)
- Google ML Kit Translation API
기타 Google Cloud 제품/페이지
Python 및 Flask
라이선스
이 튜토리얼은 Creative Commons Attribution 2.0 일반 라이선스에 따라 라이선스가 부여되며 저장소의 소스 코드는 Apache 2에 따라 라이선스가 부여됩니다.