Dinamik içeriğinizi oluşturup sunmak veya mikro hizmetler olarak REST API'leri oluşturmak için Cloud Run'ı Firebase Barındırma ile eşleştirin.
Cloud Run'ı kullanarak, bir kapsayıcı görüntüsünde paketlenmiş bir uygulamayı dağıtabilirsiniz. Ardından, Firebase Barındırma'yı kullanarak kapsayıcıya alınmış uygulamanızı tetiklemek için HTTPS isteklerini yönlendirebilirsiniz.
- Cloud Run birkaç dili (Go, Node.js, Python ve Java dahil) destekleyerek size istediğiniz programlama dilini ve çerçevesini kullanma esnekliği sunar.
- Cloud Run, alınan istekleri işlemek için kapsayıcı görüntünüzü otomatik ve yatay olarak ölçekler , ardından talep azaldığında ölçeği küçültür.
- Yalnızca istek işleme sırasında tüketilen CPU, bellek ve ağ için ödeme yaparsınız.
Örneğin, Firebase Hosting ile entegre Cloud Run için kullanım durumları ve örnekleri için sunucusuz genel bakış sayfamızı ziyaret edin.
Bu kılavuz size şunları nasıl yapacağınızı gösterir:
- Basit bir Merhaba Dünya uygulaması yazın
- Bir uygulamayı kapsayıcı hale getirin ve Container Registry'ye yükleyin
- Kapsayıcı görüntüsünü Cloud Run'a dağıtın
- Barındırma isteklerini kapsayıcılı uygulamanıza yönlendirin
Dinamik içerik sunma performansını artırmak için isteğe bağlı olarak önbellek ayarlarınızı yapabileceğinizi unutmayın.
Sen başlamadan önce
Cloud Run'ı kullanmadan önce bir Cloud Billing hesabı oluşturma, Cloud Run API'yi etkinleştirme ve gcloud
komut satırı aracını yükleme gibi bazı başlangıç görevlerini tamamlamanız gerekir.
Projeniz için faturalandırmayı ayarlayın
Cloud Run, ücretsiz kullanım kotası sunar, ancak Cloud Run'ı kullanmak veya denemek için yine de Firebase projenizle ilişkilendirilmiş bir Cloud Billing hesabınızın olması gerekir.
API'yi etkinleştirin ve SDK'yı yükleyin
Google APIs konsolunda Cloud Run API'yi etkinleştirin:
Google APIs konsolunda Cloud Run API sayfasını açın.
İstendiğinde, Firebase projenizi seçin.
Cloud Run API sayfasında Etkinleştir'e tıklayın.
Cloud SDK'yı kurun ve başlatın .
gcloud
aracının doğru proje için yapılandırıldığından emin olun:gcloud config list
Adım 1 : Örnek uygulamayı yazın
Cloud Run'ın aşağıdaki örnekte gösterilen dillere ek olarak diğer birçok dili desteklediğini unutmayın.
Gitmek
helloworld-go
adlı yeni bir dizin oluşturun, ardından dizini bu dizinle değiştirin:mkdir helloworld-go
cd helloworld-go
helloworld.go
adlı yeni bir dosya oluşturun ve ardından aşağıdaki kodu ekleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasını dinleyen temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
Node.js
helloworld-nodejs
adlı yeni bir dizin oluşturun, ardından dizini bu dizinle değiştirin:mkdir helloworld-nodejs
cd helloworld-nodejs
Aşağıdaki içeriğe sahip bir
package.json
dosyası oluşturun:index.js
adlı yeni bir dosya oluşturun, ardından aşağıdaki kodu ekleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasını dinleyen temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
Piton
helloworld-python
adlı yeni bir dizin oluşturun, ardından dizini bu dizine değiştirin:mkdir helloworld-python
cd helloworld-python
app.py
adlı yeni bir dosya oluşturun, ardından aşağıdaki kodu ekleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasını dinleyen temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
java
Java SE 8 veya üstü JDK ve CURL'yi kurun.
Bir sonraki adımda yeni web projesini oluşturmak için bunu yapmamız gerektiğini unutmayın. Daha sonra açıklanan Dockerfile, tüm bağımlılıkları kapsayıcıya yükleyecektir.
Konsoldan, cURL kullanarak yeni bir boş web projesi oluşturun, ardından komutları açın:
curl https://start.spring.io/starter.zip \ -d dependencies=web \ -d name=helloworld \ -d artifactId=helloworld \ -o helloworld.zip
unzip helloworld.zip
Bu bir SpringBoot projesi oluşturur.
src/main/java/com/example/helloworld/HelloworldApplication.java
içindekiSpringBootApplication
sınıfını,/
eşlemesini işlemek için bir@RestController
ekleyerek ve ayrıcaTARGET
ortam değişkenini sağlamak için bir@Value
alanı ekleyerek güncelleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasını dinleyen temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
2. Adım : Bir uygulamayı kapsayıcı hale getirin ve Container Registry'ye yükleyin
Kaynak dosyalarla aynı dizinde
Dockerfile
adlı yeni bir dosya oluşturarak örnek uygulamayı kapsayıcı hale getirin. Aşağıdaki içeriği dosyanıza kopyalayın.Gitmek
Node.js
Piton
java
Dockerfile dosyanızı içeren dizinden aşağıdaki komutu çalıştırarak Cloud Build'i kullanarak kapsayıcı görüntünüzü oluşturun:
gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld
Başarı üzerine, resim adını içeren bir BAŞARI mesajı göreceksiniz.
(gcr.io/ PROJECT_ID /helloworld
).
Konteyner görüntüsü artık Container Registry'de saklanır ve istenirse yeniden kullanılabilir.
Kapsayıcınızı yerel olarak oluşturmak için Cloud Build yerine Docker'ın yerel olarak yüklenmiş bir sürümünü kullanabileceğinizi unutmayın.
3. Adım : Kapsayıcı görüntüsünü Cloud Run'a dağıtın
Aşağıdaki komutu kullanarak dağıtın:
gcloud run deploy --image gcr.io/PROJECT_ID/helloworld
İstendiğinde:
- Bir bölge seçin (örneğin
us-central1
) - Hizmet adını onaylayın (örneğin,
helloworld
) - Kimliği doğrulanmamış çağrılara izin vermek için
Y
yanıtı verin
- Bir bölge seçin (örneğin
Dağıtımın tamamlanması için birkaç dakika bekleyin. Başarılı olduğunda, komut satırı hizmet URL'sini görüntüler. Örneğin:
https://helloworld- RANDOM_HASH -us-central1.a.run.appHizmet URL'sini bir web tarayıcısında açarak dağıtılan kapsayıcınızı ziyaret edin.
Bir sonraki adım, Firebase tarafından barındırılan siteniz için dinamik içerik oluşturabilmesi için bu kapsayıcıya alınmış uygulamaya bir Firebase Barındırma URL'sinden nasıl erişeceğiniz konusunda size yol gösterir.
4. Adım: Barındırma isteklerini kapsayıcılı uygulamanıza yönlendirin
Yeniden yazma kuralları ile belirli kalıplarla eşleşen istekleri tek bir hedefe yönlendirebilirsiniz.
Aşağıdaki örnek, barındırma sitenizdeki /helloworld
sayfasından gelen tüm isteklerin, helloworld
konteyner örneğinizin başlatılmasını ve çalıştırılmasını tetiklemek için nasıl yönlendirileceğini gösterir.
Emin olun:
Firebase CLI'nin en son sürümüne sahipsiniz.
Firebase Hosting'i başlattınız.
CLI'yi yükleme ve Barındırmayı başlatma hakkında ayrıntılı talimatlar için, Barındırma için Başlarken kılavuzuna bakın.
firebase.json
dosyanızı açın.hosting
bölümünün altına aşağıdakirewrite
yapılandırmasını ekleyin:"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) } } ] }
Proje dizininizin kökünden aşağıdaki komutu çalıştırarak barındırma yapılandırmanızı sitenize dağıtın:
firebase deploy --only hosting
Bu özellik sayesinde, sitenizin dinamik içeriğini oluşturmak için Cloud Run hizmetinizin revizyonunun, statik Hosting kaynaklarınız ve Hosting yapılandırmanız ile senkronize olmasını sağlayabilirsiniz. Ayrıca bu özellik, yeniden yazmalarınızı Cloud Run on Hosting önizleme kanallarına önizlemenizi sağlar.
hosting.rewrites
yapılandırmasının birrun
bloğuna"pingTag": true
eklerseniz, statik Barındırma kaynaklarınız ve yapılandırmanız, dağıtım sırasında Cloud Run hizmetinin en son revizyonuna sabitlenir. Sitenizin bir sürümünü geri alırsanız "sabitlenmiş" Cloud Run hizmetinin revizyonu da geri alınır.Bu özellik, hizmet başına 1000 etiket ve bölge başına 2000 etiket sınırına sahip Cloud Run etiketlerine dayanır. Bu, yüzlerce dağıtımdan sonra bir sitenin en eski sürümlerinin çalışmayı durdurabileceği anlamına gelir.
Kapsayıcınıza artık aşağıdaki URL'ler aracılığıyla erişilebilir:
Firebase alt alan adlarınız:
PROJECT_ID .web.app/
vePROJECT_ID .firebaseapp.com/
Tüm bağlı özel alanlar :
CUSTOM_DOMAIN /
Yeniden yazma kuralları hakkında daha fazla ayrıntı için Barındırma yapılandırma sayfasını ziyaret edin. Çeşitli Barındırma yapılandırmaları için yanıtların öncelik sırasını da öğrenebilirsiniz.
Yerel olarak test edin
Geliştirme sırasında kapsayıcı görüntünüzü yerel olarak çalıştırabilir ve test edebilirsiniz. Ayrıntılı talimatlar için Cloud Run belgelerini ziyaret edin.
Sonraki adımlar
Dinamik içeriğinizin küresel bir CDN'de önbelleğe alınmasını ayarlayın .
Firebase Admin SDK'yı kullanarak diğer Firebase hizmetleriyle etkileşime geçin.
Kapsayıcıları kurmak, yönetmek ve yapılandırmak için ayrıntılı nasıl yapılır kılavuzları da dahil olmak üzere Cloud Run hakkında daha fazla bilgi edinin.
Cloud Run için fiyatlandırmayı , kotaları ve sınırları inceleyin.