Verknüpfen Sie Cloud Run mit Firebase Hosting, um dynamische Inhalte zu generieren und bereitzustellen oder REST APIs als Mikrodienste zu erstellen.
Mit Cloud Run können Sie eine in einem Container-Image verpackte Anwendung bereitstellen. Mit Firebase Hosting können Sie dann HTTPS-Anfragen weiterleiten, um Ihre containerisierte App auszulösen.
- Cloud Run unterstützt mehrere Sprachen darunter Go, Node.js, Python und Java. So können Sie die Programmiersprache und das Framework Ihrer Wahl verwenden.
- Cloud Run skaliert das Container-Image automatisch horizontal, damit die empfangenen Anfragen bearbeitet werden können, und skaliert es wieder herunter, wenn der Bedarf sinkt.
- Sie zahlen nur für die CPU, den Arbeitsspeicher und die Netzwerknutzung, die bei der Verarbeitung von Anfragen anfallen.
Beispiele für Anwendungsfälle und Beispiele für Cloud Run in Kombination mit Firebase Hosting, finden Sie in unserer Übersicht zu serverlosen Diensten.
In dieser Anleitung erfahren Sie, wie Sie Folgendes tun:
- Eine einfache Hello World-Anwendung schreiben
- Eine App containerisieren und in Artifact Registry hochladen
- Das Container-Image in Cloud Run bereitstellen
- Hosting-Anfragen an Ihre containerisierte App weiterleitenHosting
Hinweis: Sie können optional Ihre Cache-Einstellungen optimieren, um die Leistung bei der Bereitstellung dynamischer Inhalte zu verbessern.
Hinweis
Bevor Sie Cloud Run verwenden können, müssen Sie einige erste Schritte ausführen,
z. B. ein Cloud Billing Konto einrichten, die Cloud Run
API aktivieren und das gcloud Befehlszeilentool installieren.
Abrechnung für Ihr Projekt einrichten
Cloud Run bietet ein kostenloses Nutzungskontingent, Sie benötigen jedoch ein Cloud Billing-Konto, das mit Ihrem Firebase-Projekt verknüpft ist, um Cloud Run zu verwenden oder auszuprobieren.
API aktivieren und SDK installieren
Aktivieren Sie die Cloud Run API in der Google APIs Console:
Öffnen Sie die Cloud Run API-Seite in der Google APIs Console.
Wählen Sie Ihr Firebase-Projekt aus, wenn Sie dazu aufgefordert werden.
Klicken Sie auf der Seite „Cloud Run API“ auf Aktivieren.
Installieren und initialisieren Sie das Cloud SDK.
Prüfen Sie, ob das
gcloud-Tool für das richtige Projekt konfiguriert ist:gcloud config list
Schritt 1: Beispielanwendung schreiben
Beachten Sie, dass Cloud Run zusätzlich zu den im folgenden Beispiel gezeigten Sprachen viele andere Sprachen unterstützt.
Go
Erstellen Sie ein neues Verzeichnis mit dem Namen
helloworld-gound wechseln Sie dann in dieses Verzeichnis:mkdir helloworld-go
cd helloworld-go
Erstellen Sie eine neue Datei mit dem Namen
helloworld.gound fügen Sie den folgenden Code hinzu:Mit diesem Code wird ein einfacher Webserver erstellt, der den von der Umgebungsvariable
PORTdefinierten Port überwacht.
Die Anwendung ist jetzt fertig und kann containerisiert und dann in Artifact Registry hochgeladen werden.
Node.js
Erstellen Sie ein neues Verzeichnis mit dem Namen
helloworld-nodejsund wechseln Sie dann in dieses Verzeichnis:mkdir helloworld-nodejs
cd helloworld-nodejs
Erstellen Sie eine
package.json-Datei mit folgendem Inhalt:Erstellen Sie eine neue Datei mit dem Namen
index.jsund fügen Sie den folgenden Code hinzu:Mit diesem Code wird ein einfacher Webserver erstellt, der den von der Umgebungsvariable
PORTdefinierten Port überwacht.
Die Anwendung ist jetzt fertig und kann containerisiert und dann in Artifact Registry hochgeladen werden.
Python
Erstellen Sie ein neues Verzeichnis mit dem Namen
helloworld-pythonund wechseln Sie dann in dieses Verzeichnis:mkdir helloworld-python
cd helloworld-python
Erstellen Sie eine neue Datei mit dem Namen
app.pyund fügen Sie den folgenden Code hinzu:Mit diesem Code wird ein einfacher Webserver erstellt, der den von der Umgebungsvariable
PORTdefinierten Port überwacht.
Die Anwendung ist jetzt fertig und kann containerisiert und dann in Artifact Registry hochgeladen werden.
Java
Installieren Sie das Java SE Development Kit Version 8 oder höher und CURL.
Dies ist nur erforderlich, damit wir im nächsten Schritt das neue Webprojekt erstellen können. Das weiter unten beschriebene Dockerfile wird dann später alle Abhängigkeiten in den Container laden.
Erstellen Sie über die Konsole mit den Befehlen „cURL“ und „unzip“ ein neues, leeres Webprojekt:
curl https://start.spring.io/starter.zip \ -d dependencies=web \ -d name=helloworld \ -d artifactId=helloworld \ -o helloworld.zipunzip helloworld.zip
Dadurch wird ein SpringBoot-Projekt erstellt.
Aktualisieren Sie die
SpringBootApplicationKlasse insrc/main/java/com/example/helloworld/HelloworldApplication.javadurch Hinzufügen eines@RestControllerzur Verarbeitung der/Zuordnung und fügen Sie auch ein@ValueFeld hinzu, um dieTARGETUmgebungsvariable bereitzustellen:Mit diesem Code wird ein einfacher Webserver erstellt, der den von der Umgebungsvariable
PORTdefinierten Port überwacht.
Die Anwendung ist jetzt fertig und kann containerisiert und dann in Artifact Registry hochgeladen werden.
Schritt 2: Eine App containerisieren und in Artifact Registry hochladen
Erstellen Sie zum Containerisieren der Beispielanwendung in dem Verzeichnis, in dem sich die Quelldateien befinden, eine neue Datei namens
Dockerfile. Kopieren Sie den folgenden Inhalt in die Datei.Go
Node.js
Python
Java
Erstellen Sie das Container-Image mit Cloud Build. Dazu führen Sie folgenden Befehl in dem Verzeichnis aus, in dem sich das Dockerfile befindet:
gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld
Bei Erfolg wird eine SUCCESS-Meldung mit dem Image-Namen
(gcr.io/PROJECT_ID/helloworld) angezeigt.
Das Container-Image wird jetzt in Artifact Registry gespeichert und kann bei Bedarf wiederverwendet werden.
Anstelle von Cloud Build können Sie auch eine lokal installierte Version von Docker verwenden, um den Container lokal zu erstellen.
Schritt 3: Container-Image in Cloud Run bereitstellen
Stellen Sie es mit dem folgenden Befehl bereit:
gcloud run deploy --image gcr.io/PROJECT_ID/helloworld
Tun Sie Folgendes, wenn Sie dazu aufgefordert werden:
- Wählen Sie eine Region aus, z. B.
us-central1. - Bestätigen Sie den Dienstnamen, z. B.
helloworld. - Antworten Sie mit
Yauf allow unauthenticated invocations (nicht authentifizierte Aufrufe zulassen).
- Wählen Sie eine Region aus, z. B.
Warten Sie einige Sekunden, bis die Bereitstellung abgeschlossen ist. Bei Erfolg wird in der Befehlszeile die Dienst-URL angezeigt. Beispiel:
https://helloworld-RANDOM_HASH-us-central1.a.run.app Rufen Sie den bereitgestellten Container auf. Dazu öffnen Sie in einem Webbrowser die Dienst-URL.
Im nächsten Schritt erfahren Sie, wie Sie auf diese containerisierte App über eine Firebase Hosting URL zugreifen können, damit sie dynamische Inhalte für Ihre auf Firebase gehostete Website generieren kann.
Schritt 4:Hosting-Anfragen an Ihre containerisierte App weiterleiten
Mit Umschreibungsregeln können Sie Anfragen , die bestimmten Mustern entsprechen, an ein einzelnes Ziel weiterleiten.
Im folgenden Beispiel wird gezeigt, wie Sie alle Anfragen von der Seite
/helloworld auf Ihrer Hosting Website weiterleiten, um den Start und die Ausführung von
Ihrer helloworld Containerinstanz auszulösen.
Sie müssen Folgendes sicherstellen:
Sie haben die neueste Version der Firebase CLI.
Sie haben Firebase Hosting initialisiert.
Eine detaillierte Anleitung zur Installation der CLI und zur Initialisierung Hosting finden Sie im Leitfaden Erste Schritte mit Hosting.
Öffnen Sie die Datei
firebase.json.Fügen Sie unter dem Abschnitt
hostingdie folgenderewrite-Konfiguration hinzu:"hosting": { // ... // Add the "rewrites" attribute within "hosting" "rewrites": [ { "source": "/helloworld", "run": { "serviceId": "helloworld", // "service name" (from when you deployed the container image) "region": "us-central1", // optional (if omitted, default is us-central1) "pinTag": true // optional (see note below) } } ] }
Stellen Sie Ihre Hosting-Konfiguration auf Ihrer Website bereit. Führen Sie dazu den folgenden Befehl im Stammverzeichnis Ihres Projektverzeichnisses aus:
firebase deploy --only hosting
Ihr Container ist jetzt über die folgenden URLs erreichbar:
Ihre Firebase-Subdomains:
PROJECT_ID.web.app/undPROJECT_ID.firebaseapp.com/Alle verbundenen benutzerdefinierten Domains:
CUSTOM_DOMAIN/
Weitere Informationen zu Umschreibungsregeln finden Sie auf der Hosting Konfigurationsseite für mehr Details. Sie können sich auch über die Prioritätsreihenfolge von Antworten für verschiedene Hosting Konfigurationen informieren.
Lokal testen
Während der Entwicklung haben Sie die Möglichkeit, das Container-Image lokal auszuführen und zu testen. Eine detaillierte Anleitung finden Sie in der Cloud Run Dokumentation.
Nächste Schritte
Caching Ihrer dynamischen Inhalte in einem globalen CDN einrichten.
Mit dem Firebase Admin SDK mit anderen Firebase-Diensten interagieren
Weitere Informationen zu Cloud Run, einschließlich detaillierter Anleitungen zum Einrichten, Verwalten und Konfigurieren von Containern
Preise sowie Kontingente und Limits für ansehenCloud Run