Ihr Firebase App Hosting Back-End kann eine Verbindung zu einem Virtual Private Cloud -Netzwerk (VPC) herstellen. So kann Ihr Firebase App Hosting Back-End auf Back-End-Dienste zugreifen, die nicht über öffentliche IP-Adressen erreichbar sind, z. B. Cloud SQL, Spanner, Cloud Memorystore, Compute Engine oder interne Kubernetes-Microservices.
Der VPC-Zugriff ist nur zur Laufzeit (über Ihren Cloud Run Container) und nicht zur Build-Zeit (Cloud Build) verfügbar.
Verbindung zu einem VPC-Netzwerk herstellen
- Ausgehender Direct VPC Traffic: Einfacher, schneller und kostengünstiger. Verwendet eine IP-Adresse pro Container. Für die meisten Anwendungsfälle empfohlen.
- Serverlose Connectors: Pools von IP-Adressen für größere Anwendungen. Erfordert die Zahlung für die zugrunde liegende VM. Preisdetails finden Sie auf der Seite „VPC-Preise“ unter „Serverloser VPC-Zugriff“.
In apphosting.yaml konfigurieren
Verwenden Sie die Zuordnung vpcAccess in der Datei apphosting.yaml, um den Zugriff zu konfigurieren.
Verwenden Sie entweder einen vollqualifizierten Netzwerk-/Connector-Namen oder eine ID. Durch die Verwendung von IDs ist die Portabilität zwischen Staging- und Produktionsumgebungen mit unterschiedlichen Connectors/Netzwerken möglich.
Konfiguration für ausgehenden Direct VPC-Traffic (apphosting.yaml):
runConfig:
vpcAccess:
egress: PRIVATE_RANGES_ONLY # Default value
networkInterfaces:
# Specify at least one of network and/or subnetwork
- network: my-network-id
subnetwork: my-subnetwork-id
Konfiguration für serverlose Connectors (apphosting.yaml):
runConfig:
vpcAccess:
egress: ALL_TRAFFIC
connector: connector-id
Beispiel: Verbindung zu Memorystore for Redis über eine Next.js-App herstellen
Caching-Systeme wie Redis oder Memcached werden häufig verwendet, um eine schnelle Daten Caching-Schicht für eine App zu erstellen. In diesem Beispiel erfahren Sie, wie Sie Memorystore for Redis im selben Google Cloud Projekt wie Ihr Firebase App Hosting Back-End einrichten und über ausgehenden Direct VPC-Trafficeine Verbindung dazu herstellen.
Schritt 0: Memorystore for Redis-Instanz erstellen
- Rufen Sie in der Google Cloud console die
Memorystore for Redis page
auf.
- Achten Sie darauf, dass dasselbe Projekt ausgewählt ist, das Sie für Firebase App Hosting verwenden.
- Wenn Sie nicht auf diese Seite zugreifen können, prüfen Sie, ob die Abrechnung für Ihr Projekt aktiviert ist und ob Sie die Memorystore API aktiviert haben.
- Wählen Sie Instanz erstellen aus.
- Konfigurieren Sie die neue Instanz mit den gewünschten Einstellungen. Hier sind einige
Beispielwerte, die Sie verwenden können:
- Geben Sie unter Instanz-ID
my-redis-cacheein. - Geben Sie unter Anzeigename
Redis cacheein. - Wählen Sie unter der Stufenauswahl die Option Basis aus. Die Basis-Stufe bezeichnet einen eigenständigen Redis-Knoten, im Gegensatz zur Standardstufe, die zur Sicherung Ihrer Daten einen Replikatknoten verwendet.
- Wählen Sie im Auswahlfeld Region die Region Ihres App Hosting Back-Ends aus. Achten Sie darauf, dass dieser Wert mit der Region Ihres Back-Ends übereinstimmt.
- Wählen Sie in der Zonenauswahl Beliebig aus.
- Geben Sie unter Kapazität
5ein. Dadurch wird die Instanzkapazität auf 5 GB festgelegt. - Wählen Sie unter Version die Option
5.0aus (empfohlen). - Wählen Sie in der Auswahl Autorisiertes Netzwerk die Option Standard aus.
- Geben Sie unter Instanz-ID
Schritt 1: apphosting.yaml mit Ihrer VPC-Netzwerk-ID aktualisieren
- Rufen Sie in der Google Cloud Console die Seite „VPC-Netzwerke“ auf.
- Suchen Sie die VPC-Netzwerk-ID für Ihre Memorystore for Redis-Instanz. Sie ist
oft
default. Konfigurieren Sie den ausgehenden Direct VPC-Traffic in
apphosting.yamlmit der VPC Netzwerk-ID:runConfig: vpcAccess: egress: PRIVATE_RANGES_ONLY # Default value networkInterfaces: - network: my-network-id
Schritt 2: Umgebungsvariablen hinzufügen, die Ihre App zu Redis weiterleiten
- Die Verbindungsinformationen (Host und Port) finden Sie auf dem Tab „Verbindungen“ Ihrer Memorystore for Redis-Instanz in der Google Cloud Console.
Stellen Sie mit den Umgebungsvariablen
REDISPORTundREDISHOSTeine Verbindung zu Redis her. Legen Sie diese inapphosting.yamlmit den Host- und Portwerten aus der Google Cloud Console fest:env: # Sample only. Use actual values provided by Memorystore - variable: REDISPORT value: 6379 - variable: REDISHOST value: 10.127.16.3
Schritt 3: Redis in Ihrer App verwenden
Installieren Sie das Redis-npm-Paket:
npm install redis@latestGreifen Sie über Ihren Code auf den Redis-Cache zu. Verwenden Sie die im vorherigen Schritt konfigurierten Umgebungsvariablen. So können Sie beispielsweise in einem Next.js-Routen-Handler aus einem Cache lesen:
src/lib/redis.jsimport { createClient } from "redis"; // Set these environment variables in apphosting.yaml const REDISHOST = process.env.REDISHOST; const REDISPORT = process.env.REDISPORT; let redisClient; export async function getClient(req, res) { // Only connect if a connection isn't already available if (!redisClient) { redisClient = await createClient(REDISPORT, REDISHOST) .on("error", (err) => console.error("Redis Client Error", err)) .connect(); } return redisClient; }src/app/counter/route.jsimport { getClient } from "@/lib/redis.js"; export async function GET(request) { const redisClient = await getClient(); const count = await redisClient.get("counter"); return Response.json({ count }); } export async function POST(request) { const redisClient = await getClient(); const count = await redisClient.incr("counter"); return Response.json({ count }); }
Schritt 4 (optional): App für die lokale Entwicklung konfigurieren
Der Firebase App Hosting Emulator kann Werte mit
apphosting.emulator.yaml überschreiben. Hier können Sie den Wert von REDISHOST so ändern, dass er auf den Localhost verweist, damit Sie lokal mit einer lokalen Installation von Redis entwickeln können.
- Redis auf Ihrem lokalen Computer installieren
Erstellen oder bearbeiten Sie
apphosting.emulators.yaml, um auf Ihre lokale Instanz zu verweisen:env: - variable: REDISHOST value: 127.0.0.1