1. Übersicht
Diese Reihe von Codelabs (eigenständige, praktische Anleitungen) soll Entwicklern helfen, die verschiedenen Optionen zu verstehen, die ihnen beim Bereitstellen ihrer Anwendungen zur Verfügung stehen. In diesem Codelab erfahren Sie, wie Sie die Google Cloud Translation API mit Python verwenden und entweder lokal ausführen oder auf einer serverlosen Computing-Plattform in der Cloud (App Engine, Cloud Functions oder Cloud Run) bereitstellen. Die Beispiel-App im Repository dieses Tutorials kann (mindestens) auf acht verschiedene Arten bereitgestellt werden, mit nur geringfügigen Konfigurationsänderungen:
- Lokaler Flask-Server (Python 2)
- Lokaler Flask-Server (Python 3)
- App Engine (Python 2)
- App Engine (Python 3)
- Cloud Functions (Python 3)
- Cloud Run (Python 2 über Docker)
- Cloud Run (Python 3 über Docker)
- Cloud Run (Python 3 über Cloud Buildpacks)
In diesem Codelab geht es hauptsächlich um die Bereitstellung dieser App auf den oben fett gedruckten Plattformen.
Sie lernen, wie Sie
- Google Cloud APIs verwenden, insbesondere die Cloud Translation API (erweitert/v3)
- Eine einfache Webanwendung lokal ausführen oder auf einer serverlosen Cloud-Rechenplattform bereitstellen
Voraussetzungen
- Ein Google Cloud-Projekt mit einem aktiven Cloud-Rechnungskonto
- Flask, das für die lokale Ausführung installiert ist, oder eine serverlose Cloud-Computing-Plattform, die für cloudbasierte Bereitstellungen aktiviert ist
- Grundlegende Python-Kenntnisse
- Grundkenntnisse in den grundlegenden Befehlen des Betriebssystems
Umfrage
Wie möchten Sie diese Anleitung verwenden?
Wie würden Sie Ihre Erfahrung mit Python bewerten?
Wie würden Sie Ihre Erfahrungen mit der Nutzung von Google Cloud-Diensten bewerten?
2. Einrichtung und Anforderungen
Einrichtung der Umgebung im eigenen Tempo
- Melden Sie sich in der Google Cloud Console an und erstellen Sie ein neues Projekt oder verwenden Sie ein vorhandenes. Wenn Sie noch kein Gmail- oder Google Workspace-Konto haben, müssen Sie ein Konto erstellen.
- Der Projektname ist der Anzeigename für die Teilnehmer dieses Projekts. Es handelt sich um einen Zeichenstring, der nicht von Google APIs verwendet wird. Sie können ihn jederzeit aktualisieren.
- Die Projekt-ID muss für alle Google Cloud-Projekte eindeutig sein und kann nach der Festlegung nicht mehr geändert werden. Die Cloud Console generiert automatisch einen eindeutigen String. In den meisten Codelabs müssen Sie auf die Projekt-ID verweisen, die normalerweise als
PROJECT_ID
gekennzeichnet ist. Wenn Ihnen die ID nicht gefällt, generieren Sie eine andere zufällige ID oder versuchen Sie, Ihre eigene zu verwenden und prüfen Sie, ob sie verfügbar ist. Nach dem Erstellen des Projekts wird es „eingefroren“. - Es gibt einen dritten Wert, die Projektnummer, die von einigen APIs verwendet wird. Weitere Informationen zu diesen drei Werten finden Sie in der Dokumentation.
- Als Nächstes müssen Sie die Abrechnung in der Cloud Console aktivieren, um Cloud-Ressourcen/-APIs verwenden zu können. Die Ausführung dieses Codelabs sollte nur wenige Kosten verursachen, wenn überhaupt. Wenn Sie die Ressourcen herunterfahren möchten, damit keine Kosten über diese Anleitung hinaus anfallen, folgen Sie der Anleitung zum Bereinigen am Ende des Codelabs. Neuen Nutzern der Google Cloud Platform steht das kostenlose Testprogramm mit einem Guthaben von 300$ zur Verfügung.
3. Translation API aktivieren
Cloud APIs aktivieren
In diesem Abschnitt erfahren Sie, wie Sie Google APIs allgemein aktivieren. Für unsere Beispiel-App aktivieren Sie die Cloud Translation API, Cloud Run und die Cloud Artifact Registry.
Einführung
Unabhängig davon, welche Google API Sie in Ihrer Anwendung verwenden möchten, muss sie aktiviert sein. Das folgende Beispiel zeigt zwei Möglichkeiten, die Cloud Vision API zu aktivieren. Nachdem Sie gelernt haben, wie Sie eine Cloud API aktivieren, können Sie auch andere APIs aktivieren, da der Vorgang ähnlich ist.
Option 1: Über Cloud Shell oder die Befehlszeile
Das Aktivieren von APIs über die Cloud Console ist zwar gängiger, einige Entwickler bevorzugen jedoch die Befehlszeile. Dazu müssen Sie den „Dienstnamen“ einer API suchen. Sie sieht aus wie eine URL: SERVICE_NAME
.googleapis.com
. Sie finden sie im Diagramm zu unterstützten Produkten oder können sie programmatisch mit der Google Discovery API abfragen.
Mit diesen Informationen können Sie in Cloud Shell (oder in Ihrer lokalen Entwicklungsumgebung mit installiertem gcloud
-Befehlszeilentool) eine API so aktivieren:
gcloud services enable SERVICE_NAME.googleapis.com
Mit diesem Befehl wird beispielsweise die Cloud Vision API aktiviert:
gcloud services enable vision.googleapis.com
Mit diesem Befehl werden die folgenden App Engine-Funktionen aktiviert:
gcloud services enable appengine.googleapis.com
Sie können auch mehrere APIs mit einer einzigen Anfrage aktivieren. Mit dieser Befehlszeile werden beispielsweise Cloud Run, Cloud Artifact Registry und die Cloud Translation API aktiviert:
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
Option 2: Über die Cloud Console
Sie können die Vision API auch im API Manager aktivieren. Rufen Sie in der Cloud Console API Manager auf und wählen Sie Bibliothek aus.
Wenn Sie die Cloud Vision API aktivieren möchten, geben Sie in die Suchleiste „vision“ ein. Daraufhin werden alle Elemente angezeigt, die mit dem Gesuchten übereinstimmen:
Wählen Sie die API aus, die Sie aktivieren möchten, und klicken Sie auf Aktivieren:
Kosten
Viele Google APIs können kostenlos verwendet werden, die Nutzung von Google Cloud-Produkten und ‑APIs ist jedoch nicht kostenlos. Wenn Sie Cloud APIs aktivieren, werden Sie möglicherweise nach einem aktiven Rechnungskonto gefragt. Einige Google Cloud-Produkte bieten jedoch eine „Immer kostenlos“-Stufe (täglich/monatlich), die Sie überschreiten müssen, damit Ihnen Kosten in Rechnung gestellt werden. Andernfalls wird Ihre Kreditkarte (oder das angegebene Abrechnungsmittel) nicht belastet.
Nutzer sollten sich vor der Aktivierung die Preisinformationen für jede API ansehen und insbesondere darauf achten, ob es eine kostenlose Stufe gibt und wenn ja, welche. Wenn Sie die Cloud Vision API aktivieren, sollten Sie sich die Preisinformationen ansehen. Cloud Vision hat ein kostenloses Kontingent. Solange Sie die Limits insgesamt (innerhalb eines Monats) einhalten, fallen keine Kosten an.
Preise und kostenlose Stufen variieren je nach Google API. Beispiele:
- Google Cloud/GCP: Jedes Produkt wird unterschiedlich abgerechnet und ist in der Regel nach vCPU-Zyklus, Speicherverbrauch, Speichernutzung oder Pay-per-Use abgerechnet. Weitere Informationen zur kostenlosen Stufe finden Sie oben.
- Google Maps: Bietet eine Reihe von APIs und ein kostenloses monatliches Guthaben von 200$.
- Google Workspace (früher G Suite) APIs: Die Nutzung ist bis zu bestimmten Limits kostenlos und wird durch eine monatliche Workspace-Abogebühr abgedeckt. Die APIs für Gmail, Google Drive, Kalender, Docs, Tabellen und Präsentationen werden also nicht direkt abgerechnet.
Die Abrechnung verschiedener Google-Produkte unterscheidet sich. Weitere Informationen finden Sie in der Dokumentation Ihrer API.
Zusammenfassung
Da Sie nun wissen, wie Sie Google APIs allgemein aktivieren, rufen Sie den API-Manager auf und aktivieren Sie die Cloud Translation API, Cloud Run und Cloud Artifact Registry, falls Sie dies noch nicht getan haben. Sie aktivieren die erste Option, da sie von unserer Anwendung verwendet wird. Sie aktivieren Letzteres, da dort unsere Container-Images gespeichert werden, bevor sie bereitgestellt werden, um Ihren Cloud Run-Dienst zu starten. Sie müssen diese Option also aktivieren. Wenn Sie sie lieber alle mit dem gcloud
-Tool aktivieren möchten, geben Sie stattdessen den folgenden Befehl über das Terminal aus:
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
Das monatliche Kontingent ist zwar nicht auf der Übersichtsseite der Stufe „Immer kostenlos“ aufgeführt, aber auf der Preisseite der Translation API wird angegeben, dass alle Nutzer monatlich eine feste Anzahl von übersetzten Zeichen erhalten. Wenn Sie unter diesem Grenzwert bleiben, fallen keine Kosten für die API an. Falls weitere Google Cloud-bezogene Kosten anfallen, werden diese am Ende im Abschnitt „Aufräumen“ erläutert.
4. Beispiel-App-Code abrufen
Klonen Sie den Code in dem Repository lokal oder in Cloud Shell (mit dem Befehl git clone
) oder laden Sie die ZIP-Datei über die grüne Schaltfläche Code herunter, wie im folgenden Screenshot gezeigt:
Nachdem Sie alles haben, erstellen Sie eine vollständige Kopie des Ordners für diese Anleitung, da Sie wahrscheinlich Dateien löschen oder ändern müssen. Wenn Sie eine andere Bereitstellung durchführen möchten, können Sie mit dem Kopieren des Originals beginnen, damit Sie es nicht noch einmal klonen oder herunterladen müssen.
5. Beispiel-App ansehen
Die Beispiel-App ist eine einfache Ableitung von Google Übersetzer, bei der Nutzer aufgefordert werden, Text auf Englisch einzugeben und die entsprechende Übersetzung ins Spanische zu erhalten. Öffnen Sie jetzt die Datei main.py
, damit wir sehen können, wie sie funktioniert. Ohne die kommentierten Zeilen zur Lizenzierung sieht das oben und unten so aus:
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)))
- Durch die Importe werden die Flask-Funktionen, das
google.auth
-Modul und die Cloud Translation API-Clientbibliothek eingebunden. - Die globalen Variablen stehen für die Flask-Anwendung, die Cloud-Projekt-ID, den Translation API-Client, den übergeordneten „Speicherortpfad“ für Translation API-Aufrufe sowie die Quell- und Zielsprachen. In diesem Fall sind das Englisch (
en
) und Spanisch (es
). Sie können diese Werte jedoch in andere Sprachcodes ändern, die von der Cloud Translation API unterstützt werden. - Der große
if
-Block unten wird in der Anleitung zum Lokalen Ausführen dieser App verwendet. Dabei wird der Flask-Entwicklungsserver verwendet, um die App bereitzustellen. Dieser Abschnitt ist auch in den Anleitungen zur Cloud Run-Bereitstellung enthalten, falls der Webserver nicht im Container enthalten ist. Sie werden aufgefordert, das Binden des Servers im Container zu aktivieren. Falls Sie dies übersehen, verwendet der App-Code den Flask-Entwicklungsserver. Bei der App Engine oder Cloud Functions ist das kein Problem, da es sich um quellenbasierte Plattformen handelt, d. h. Google Cloud stellt einen Standardwebserver bereit und verwaltet ihn.
In der Mitte von main.py
befindet sich schließlich das Herzstück der Anwendung, die translate()
-Funktion:
@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)
Die Hauptfunktion übernimmt die Nutzereingabe und ruft die Translation API auf, um die eigentliche Arbeit zu erledigen. Sehen wir uns das genauer an:
- Prüfen Sie mithilfe der Variablen
local_request
, ob Anfragen von Cloud Functions stammen. Cloud Functions sendet ein eigenes Flask-Anfrageobjekt, während alle anderen (lokal ausgeführt oder in der App Engine oder Cloud Run bereitgestellt) das Anfrageobjekt direkt von Flask erhalten. - Setzen Sie die grundlegenden Variablen für das Formular zurück. Dies gilt hauptsächlich für GET-Anfragen, da POST-Anfragen Daten enthalten, die diese ersetzen.
- Wenn es sich um eine POST-Anfrage handelt, rufen Sie den zu übersetzenden Text ab und erstellen Sie eine JSON-Struktur, die die API-Metadatenanforderung darstellt. Rufen Sie dann die API auf und greifen Sie auf eine vorherige Version der API zurück, wenn der Nutzer eine ältere Bibliothek verwendet.
- Formatieren Sie die tatsächlichen Ergebnisse (POST) oder keine Daten (GET) im Vorlagenkontext und rendern Sie sie.
Der visuelle Teil der Anwendung befindet sich in der Vorlagendatei index.html
. Es werden alle zuvor übersetzten Ergebnisse angezeigt (ansonsten leer), gefolgt vom Formular, in dem Sie etwas zum Übersetzen eingeben können:
<!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. Dienst bereitstellen
Sie können Ihren Übersetzungsdienst jetzt in Cloud Run bereitstellen. Führen Sie dazu den folgenden Befehl aus:
gcloud run deploy translate --source . --allow-unauthenticated --platform managed
Die Ausgabe sollte in etwa so aussehen und einige Vorschläge für die nächsten Schritte enthalten:
$ 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
Da Ihre App jetzt weltweit verfügbar ist, sollten Sie sie unter der URL mit Ihrer Projekt-ID aufrufen können, wie in der Bereitstellungsausgabe angezeigt:
Probieren Sie es aus, indem Sie etwas übersetzen.
7. Fazit
Glückwunsch! Sie haben gelernt, wie Sie die Cloud Translation API aktivieren, die erforderlichen Anmeldedaten abrufen und eine einfache Webanwendung in Python 2 Cloud Run bereitstellen. Weitere Informationen zu dieser Bereitstellung finden Sie in dieser Tabelle im Repository.
Bereinigen
Mit der Cloud Translation API können Sie eine feste Anzahl von Zeichen pro Monat kostenlos übersetzen. Die App Engine hat auch ein kostenloses Kontingent. Das gilt auch für Cloud Functions und Cloud Run. Wenn einer der beiden Grenzwerte überschritten wird, fallen Gebühren an. Wenn Sie mit dem nächsten Codelab fortfahren möchten, müssen Sie Ihre App nicht beenden.
Wenn Sie jedoch noch nicht bereit für das nächste Tutorial sind oder befürchten, dass die gerade bereitgestellte App im Internet gefunden wird, können Sie Ihre App Engine-App deaktivieren, Ihre Cloud-Funktion löschen oder Ihren Cloud Run-Dienst deaktivieren, um Kosten zu vermeiden. Wenn Sie bereit sind, mit dem nächsten Codelab fortzufahren, können Sie die Funktion wieder aktivieren. Wenn Sie diese Anwendung oder andere Codelabs nicht weiter verwenden und alles vollständig löschen möchten, können Sie Ihr Projekt beenden.
Außerdem fallen beim Bereitstellen auf einer serverlosen Computing-Plattform von Google Cloud geringe Erstellungs- und Speicherkosten an. Cloud Build und Cloud Storage haben jeweils ein eigenes kostenloses Kontingent. Für mehr Transparenz erstellt Cloud Build Ihr Anwendungs-Image, das dann entweder in der Cloud Container Registry oder in der Artifact Registry, ihrem Nachfolger, gespeichert wird. Das Speichern dieses Bildes beansprucht einen Teil dieses Kontingents, ebenso wie der ausgehende Netzwerktraffic bei der Übertragung dieses Bildes an den Dienst. Möglicherweise leben Sie jedoch in einer Region, in der es keine solche kostenlose Stufe gibt. Achten Sie daher auf Ihre Speichernutzung, um potenzielle Kosten zu minimieren.
8. Zusätzliche Ressourcen
In den folgenden Abschnitten finden Sie zusätzliche Lesematerialien sowie empfohlene Übungen, mit denen Sie Ihr Wissen aus diesem Tutorial erweitern können.
Zusätzliche Studie
Sie haben jetzt einige Erfahrung mit der Translation API gesammelt. Sehen wir uns nun einige weitere Übungen an, um Ihre Fähigkeiten zu erweitern. Ändern Sie unsere Beispielanwendung, um mit dem Lernpfad fortzufahren:
- Schließen Sie alle anderen Versionen dieses Codelabs ab, um den Code lokal auszuführen oder auf serverlosen Computing-Plattformen von Google Cloud bereitzustellen (siehe README des Repos).
- Führen Sie dieses Tutorial mit einer anderen Programmiersprache aus.
- Ändern Sie diese Anwendung, um andere Ausgangs- oder Zielsprachen zu unterstützen.
- Diese Anwendung so aktualisieren, dass Text in mehrere Sprachen übersetzt werden kann; ändern Sie die Vorlagendatei so, dass ein Drop-down-Menü mit unterstützten Zielsprachen angezeigt wird.
Weitere Informationen
Google App Engine
- App Engine-Startseite
- App Engine-Dokumentation
- App Engine Python 3 – Kurzanleitung
- Standarddienstkonten für die App Engine
- Python 2 App Engine (Standard)-Laufzeit
- Python 3 App Engine (Standard)-Laufzeit
- Unterschiede zwischen den Python 2- und Python 3-Laufzeiten der App Engine (Standard)
- App Engine (Standard) – Migrationsanleitung von Python 2 zu Python 3
Google Cloud Functions
- Cloud Functions-Startseite
- Cloud Functions-Dokumentation
- Schnellstart für Python-Cloud Functions
- Standarddienstkonten für Cloud Functions
Google Cloud Run
- Cloud Run-Startseite
- Cloud Run-Dokumentation
- Python Cloud Run-Kurzanleitung
- Standarddienstkonten für Cloud Run
Google Cloud Buildpacks, Container Registry, Artifact Registry
- Ankündigung von Cloud Buildpacks
- Cloud Buildpacks-Repository
- Cloud Artifact Registry-Startseite
- Cloud Artifact Registry-Dokumentation
- Startseite der Cloud Container Registry
- Cloud Container Registry-Dokumentation
Google Cloud Translation und Google ML Kit
- Cloud Translation-Startseite
- Cloud Translation-Dokumentation
- Preisseite der Translation API
- Alle Cloud AI/ML-APIs vom Typ „Baustein“
- Google ML Kit (Subset der Cloud-KI/ML-APIs für Mobilgeräte)
- Google ML Kit Translation API
Andere Google Cloud-Produkte/-Seiten
- Google Cloud Python-Support
- Google Cloud-Clientbibliotheken
- „Immer kostenlos“-Stufe von Google Cloud
- Gesamte Google Cloud-Dokumentation
Python und Flask
Lizenz
Dieses Tutorial ist mit einer Creative Commons Attribution 2.0 Generic License lizenziert, während der Quellcode im Repository unter Apache 2 lizenziert ist.