部署基本 ";Google 翻譯"部署於 Python 3 Cloud Functions

1. 總覽

本系列 Codelab (自學式實作教學課程) 旨在協助開發人員瞭解部署應用程式時可用的各種選項。在本程式碼研究室中,您將瞭解如何使用 Python 搭配 Google Cloud Translation API,並在本機執行或部署至 Cloud 無伺服器運算平台 (App Engine、Cloud Functions 或 Cloud Run)。本教學課程的存放區中的範例應用程式可透過 (至少) 八種不同的方式部署,只需進行少許設定變更即可:

  1. 本機 Flask 伺服器 (Python 2)
  2. 本機 Flask 伺服器 (Python 3)
  3. App Engine (Python 2)
  4. App Engine (Python 3)
  5. Cloud Functions (Python 3)
  6. Cloud Run (透過 Docker 執行 Python 2)
  7. Cloud Run (透過 Docker 執行 Python 3)
  8. Cloud Run (透過 Cloud Buildpacks 執行 Python 3)

本程式碼研究室著重於將此應用程式部署至上述粗體字的平台。

您將學到如何

軟硬體需求

問卷調查

您要如何使用這個教學課程?

閱讀並完成練習 僅閱讀

請評估您使用 Python 的體驗。

新手 中級 熟練

請評估你使用 Google Cloud 服務的體驗。

新手 中級 熟練

2. 設定和需求

自助式環境設定

  1. 登入 Google Cloud 控制台,然後建立新專案或重複使用現有專案。如果您還沒有 Gmail 或 Google Workspace 帳戶,請務必建立帳戶

96a9c957bc475304.png

b9a10ebdf5b5a448.png

a1e3c01a38fa61c2.png

  • 「Project name」是這個專案參與者的顯示名稱。這是 Google API 不會使用的字元字串,您隨時可以更新。
  • 專案 ID 在所有 Google Cloud 專案中不得重複,且無法變更 (設定後即無法變更)。Cloud 控制台會自動產生專屬字串,您通常不需要特別留意。在大多數程式碼研究室中,您需要參照專案 ID (通常會以 PROJECT_ID 表示),因此如果不喜歡這個 ID,可以產生另一個隨機 ID,也可以嘗試使用自己的 ID,看看是否可用。然後在專案建立後「凍結」。
  • 第三個值是專案編號,部分 API 會使用這個值。如要進一步瞭解這三個值,請參閱說明文件
  1. 接著,您需要在 Cloud 控制台中啟用帳單功能,才能使用 Cloud 資源/API。執行本程式碼研究室時,費用應該不會太高,甚至可能不收費。如要關閉資源,避免產生教學課程以外的帳單費用,請按照程式碼研究室結尾的「清除」操作說明進行。Google Cloud 新使用者可享有 $300 美元的免費試用期

3. 啟用 Translation API

在本節中,您將瞭解如何一般啟用 Google API。針對範例應用程式,您將啟用 Cloud Translation APICloud Functions 服務。

簡介

無論您要在應用程式中使用哪個 Google API,都必須啟用該 API。以下範例說明啟用 Cloud Vision API 的兩種方式。瞭解如何啟用一個 Cloud API 後,您就能啟用其他 API,因為兩者的程序相似。

選項 1:透過 Cloud Shell 或指令列介面

雖然大多數開發人員會透過 Cloud 控制台啟用 API,但有些開發人員則偏好透過指令列執行所有操作。如要這樣做,您必須查詢 API 的「服務名稱」。這個字串看起來像是網址: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 Console

您也可以在 API Manager 中啟用 Vision API。在 Cloud Console 中,前往 API Manager,然後選取「Library」

fb0f1d315f122d4a.png

如果您想啟用 Cloud Vision API,請在搜尋列中開始輸入「vision」,系統就會顯示與您目前輸入內容相符的項目:

2275786a24f8f204.png

選取要啟用的 API,然後按一下「啟用」

2556f923b628e31.png

費用

雖然許多 Google API 可免費使用,但 Google Cloud 產品和 API 不是免費。啟用 Cloud API 時,系統可能會要求您提供有效的帳單帳戶。不過,請務必注意,部分 Google Cloud 產品提供「永久免費」等級 (每日/每月),您必須超過這個等級,系統才會向您收取帳單費用;否則,系統不會向您的信用卡 (或指定的帳單付款工具) 收費。

使用者應在啟用任何 API 前參考定價資訊,特別是注意是否有免費方案,如果有的話,請查看相關資訊。如果您要啟用 Cloud Vision API,請查看定價資訊頁面。Cloud Vision 提供免費配額,只要總用量 (每月) 不超過配額,就不會產生任何費用。

每個 Google API 的定價和免費方案皆不相同。範例:

不同 Google 產品的收費方式不同,請務必參閱 API 說明文件瞭解相關資訊。

摘要

您現在已瞭解如何啟用 Google API,請前往 API 管理工具,並啟用 Cloud Translation APICloud Functions 服務 (如果您尚未啟用)。後者是因為應用程式會使用該服務,而前者是因為您要部署 Cloud Function。如果您想透過指令列執行此操作,請改為發出以下指令:

gcloud services enable cloudfunctions.googleapis.com translate.googleapis.com

雖然「一律免費」等級的總結頁面未列出每月配額,但Translation API 的定價頁面指出,所有使用者每月可獲得固定數量的翻譯字元。如果您未超過此門檻,就不會產生任何 API 費用。如果還有其他 Google Cloud 相關費用,我們會在結尾的「清理」一節中討論。

4. 取得範例應用程式程式碼

在本機或 Cloud Shell 中複製存放區中的程式碼 (使用 git clone 指令),或是從綠色「Code」按鈕下載 ZIP 檔案,如以下螢幕截圖所示:

5cd6110c4414cf65.png

完成所有準備工作後,請建立資料夾的完整副本,以便進行這個教學課程,因為您可能需要刪除或變更檔案。如果您想進行不同的部署作業,可以複製原始項目來重新開始,這樣就不必再次複製或下載。

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)))
  1. 匯入內容會導入 Flask 功能、google.auth 模組和 Cloud Translation API 用戶端程式庫。
  2. 全域變數代表 Flask 應用程式、Cloud 專案 ID、Translation API 用戶端、Translation API 呼叫的父項「位置路徑」,以及原文和譯文語言。在本例中,這些語言代碼為英文 (en) 和西班牙文 (es),但您可以將這些值變更為 Cloud Translation API 支援的其他語言代碼。
  3. 底部的大型 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 來執行繁重的工作。以下為你詳細說明:

  1. 請使用 local_request 變數檢查是否有來自 Cloud Functions 的要求。Cloud Functions 會傳送自己的 Flask 要求物件,而其他所有要求 (在本機執行或部署至 App Engine 或 Cloud Run) 會直接從 Flask 取得要求物件。
  2. 重設表單的基本變數。這項功能主要適用於 GET 要求,因為 POST 要求會包含取代這些資料的資料。
  3. 如果是 POST,請擷取要翻譯的文字,並建立代表 API 中繼資料需求的 JSON 結構。然後呼叫 API,如果使用者採用較舊的程式庫,則會改用舊版 API。
  4. 無論如何,請將實際結果 (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. 部署服務

如要將翻譯服務部署至 (Python 3) Cloud Functions,請執行下列指令:

gcloud functions deploy translate --runtime python37 --trigger-http --allow-unauthenticated

輸出內容應如下所示,並提供一些提示,說明後續步驟:

$ gcloud functions deploy translate --runtime python37 --trigger-http --allow-unauthenticated
Deploying function (may take a while - up to 2 minutes)...⠹
For Cloud Build Stackdriver Logs, visit: https://console.cloud.google.com/logs/viewer?project=PROJECT_ID&advancedFilter=resource.type%3Dbuild%0Aresource.labels.build_id%3D7e32429d-ec36-422c-8a8b-43c4d661a15c%0AlogName%3Dprojects%2FPROJECT_ID%2Flogs%2Fcloudbuild
Deploying function (may take a while - up to 2 minutes)...done.
availableMemoryMb: 256
buildId: 7e32429d-ec36-422c-8a8b-43c4d661a15
entryPoint: translate
httpsTrigger:
  securityLevel: SECURE_OPTIONAL
  url: https://REGION-PROJECT_ID.cloudfunctions.net/translate
ingressSettings: ALLOW_ALL
labels:
  deployment-tool: cli-gcloud
name: projects/PROJECT_ID/locations/REGION/functions/translate
runtime: python37
serviceAccountEmail: PROJECT_ID@appspot.gserviceaccount.com
sourceUploadUrl: https://storage.googleapis.com/gcf-upload-REGION-873f8448-838f-4eb2-beda-3e200a1420d/cb1cbdca-34eb-41d0-88d6-c276d5205fb.zip?GoogleAccessId=service-104690130103@gcf-admin-robot.iam.gserviceaccount.com&Expires=1619139674
status: ACTIVE
timeout: 60s
updateTime: '2021-04-23T00:32:58.065Z'
versionId: '3'

應用程式現在已在全球推出,您應該可以透過包含專案 ID 的網址存取應用程式,如部署輸出內容所示。網址應類似於:https://REGION-PROJECT_ID.cloudfunctions.net/translate,具體取決於您選取的區域和 Cloud 專案 ID。

518f1c3165f2096d.png

翻譯內容即可體驗!

539b52bd25377888.png

7. 結語

恭喜!您已瞭解如何啟用 Cloud Translation API、取得必要的憑證,以及將簡單的網頁應用程式部署至 Cloud Functions!如要進一步瞭解這項部署作業,請參閱這個存放區中的表格

清除所用資源

使用 Cloud Translation API 時,您可以每月免費翻譯固定數量的字元。App Engine 也設有免費配額Cloud FunctionsCloud Run 也是如此。超過上述限制時,系統會向您收取費用。如果您打算繼續進行下一個程式碼研究室,則不必關閉應用程式。

不過,如果您還不想繼續進行下一篇教學課程,或是擔心網路會偵測到您剛部署的應用程式,請停用 App Engine 應用程式刪除 Cloud Function,或是停用 Cloud Run 服務,以免產生費用。當您準備繼續進行下一個程式碼研究室時,可以重新啟用該研究室。另一方面,如果您不打算繼續使用這個應用程式或其他程式碼研究室,且想要完全刪除所有內容,可以關閉專案

此外,部署至 Google Cloud 無伺服器運算平台也會產生少許建構和儲存費用Cloud BuildCloud Storage 一樣,都有各自的免費配額。為提供更高的透明度,Cloud Build 會建構應用程式映像檔,然後儲存在 Cloud Container Registry 或其後繼服務 Artifact Registry 中。該圖片的儲存空間會使用部分配額,而將圖片傳輸至服務時,網路傳出也會使用部分配額。不過,您所在的區域可能沒有免付費層級,因此請注意儲存空間用量,盡量降低可能產生的費用。

8. 其他資源

在後續章節中,您可以找到其他閱讀材料和建議練習,進一步加深您在本教學課程中所學到的知識。

其他研究

您現在已對 Translation API 有些許認識,接下來我們將進行一些額外的練習,進一步提升您的技能。如要繼續學習,請修改範例應用程式,執行下列操作:

  1. 完成本程式碼研究室的所有其他版本,以便在本機上執行或部署至 Google Cloud 無伺服器運算平台 (請參閱 存放區 README)。
  2. 使用其他程式設計語言完成本教學課程。
  3. 變更這個應用程式,以支援不同的原文或譯文語言。
  4. 升級此應用程式,讓應用程式能夠將文字翻譯成多種語言;變更範本檔案,讓範本檔案顯示支援的目標語言下拉式選單。

瞭解詳情

Google App Engine

Google Cloud Functions

Google Cloud Run

Google Cloud Buildpacks、Container Registry、Artifact Registry

Google Cloud Translation 和 Google ML Kit

其他 Google Cloud 產品/頁面

Python 和 Flask

授權

本教學課程採用 Creative Commons Attribution 2.0 Generic License 授權,而存放區中的原始碼則採用 Apache 2 授權。