Dinamik içeriklerinizi oluşturup sunmak veya REST API'leri mikro hizmetler olarak oluşturmak için Cloud Run ile Firebase Hosting'yi eşleştirin.
Cloud Run kullanarak, container görüntüsünde paketlenmiş bir uygulamayı dağıtabilirsiniz. Ardından, Firebase Hosting kullanarak HTTPS isteklerini yönlendirerek kapsayıcılı uygulamanızı tetikleyebilirsiniz.
- Cloud Run, çeşitli dilleri (Go, Node.js, Python ve Java dahil) destekler. Bu sayede, istediğiniz programlama dilini ve çerçeveyi kullanma esnekliğine sahip olursunuz.
- Cloud Run Alınan istekleri işlemek için kapsayıcı resminizi otomatik olarak ve yatay yönde ölçeklendirir, talep azaldığında ise ölçeği küçültür.
- Yalnızca istek işleme sırasında kullanılan CPU, bellek ve ağ iletişimi için ödeme yaparsınız.
Cloud Run ile entegre edilmiş Firebase Hosting için örnek kullanım alanları ve örnekler için sunucusuz genel bakış sayfamızı ziyaret edin.
Bu rehberde, aşağıdakileri nasıl yapacağınız açıklanmaktadır:
- Basit bir Hello World uygulaması yazma
- Bir uygulamayı kapsayıcıya alma ve Artifact Registry'ya yükleme
- Container görüntüsünü Cloud Run'ye dağıtma
- Container mimarisine alınmış uygulamanıza Hosting istekleri yönlendirme
Dinamik içerik yayınlama performansını artırmak için önbellek ayarlarınızı isteğe bağlı olarak ayarlayabilirsiniz.
Başlamadan önce
Cloud Run aracını kullanmadan önce Cloud Billing hesabı oluşturma, Cloud Run API'sini etkinleştirme ve gcloud
komut satırı aracını yükleme gibi bazı ilk görevleri tamamlamanız gerekir.
Projeniz için faturalandırmayı ayarlama
Cloud Run ücretsiz kullanım kotası sunar ancak Cloud Run'yı kullanmak veya denemek için Firebase projenizle ilişkili bir Cloud Billing hesabınızın olması gerekir.
API'yi etkinleştirme ve SDK'yı yükleme
Google API Konsolu'nda Cloud Run API'yi etkinleştirin:
Google API Konsolu'nda Cloud Run API sayfasını açın.
İstendiğinde Firebase projenizi seçin.
Cloud Run API sayfasında Etkinleştir'i tıklayın.
Cloud SDK'yı yükleyin ve başlatın.
gcloud
aracının doğru proje için yapılandırıldığını kontrol edin:gcloud config list
1. adım: Örnek uygulamayı yazın
Cloud Run, aşağıdaki örnekte gösterilen dillerin yanı sıra birçok başka dili de destekler.
Go
helloworld-go
adlı yeni bir dizin oluşturun ve ardından dizini bu dizinle değiştirin:mkdir helloworld-go
cd helloworld-go
helloworld.go
adlı yeni bir dosya oluşturun ve aşağıdaki kodu ekleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasında dinleme yapan temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsülleştirilip Artifact Registry'ya yüklenmeye hazır.
Node.js
helloworld-nodejs
adlı yeni bir dizin oluşturun, ardından dizini bu dizine değiştirin:mkdir helloworld-nodejs
cd helloworld-nodejs
Aşağıdaki içeriklerle bir
package.json
dosyası oluşturun:index.js
adlı yeni bir dosya oluşturun ve aşağıdaki kodu ekleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasında dinleme yapan temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsülleştirilip Artifact Registry'ya yüklenmeye hazır.
Python
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 ve aşağıdaki kodu ekleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasında dinleme yapan temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsülleştirilip Artifact Registry'ya yüklenmeye hazır.
Java
Java SE 8 veya sonraki JDK ve CURL'yi yükleyin.
Bu işlemi yalnızca bir sonraki adımda yeni web projesini oluşturmak için yapmamız gerektiğini unutmayın. Daha sonra açıklanacak olan Dockerfile, tüm bağımlılıkları container'a yükler.
Konsoldan cURL ve unzip komutlarını kullanarak yeni bir boş web projesi oluşturun:
curl https://start.spring.io/starter.zip \ -d dependencies=web \ -d name=helloworld \ -d artifactId=helloworld \ -o helloworld.zip
unzip helloworld.zip
Bu komut, SpringBoot projesi oluşturur.
SpringBootApplication
sınıfını,src/main/java/com/example/helloworld/HelloworldApplication.java
içinde/
eşlemesini işlemek için@RestController
ekleyerek güncelleyin. Ayrıca,TARGET
ortam değişkenini sağlamak için@Value
alanı da ekleyin:Bu kod,
PORT
ortam değişkeni tarafından tanımlanan bağlantı noktasında dinleme yapan temel bir web sunucusu oluşturur.
Uygulamanız tamamlandı ve kapsülleştirilip Artifact Registry'ya yüklenmeye hazır.
2. adım: Bir uygulamayı kapsülleyin ve Artifact Registry'a yükleyin
Kaynak dosyalarla aynı dizinde
Dockerfile
adlı yeni bir dosya oluşturarak örnek uygulamayı kapsayıcıya alın. Aşağıdaki içeriği dosyanıza kopyalayın.Go
Node.js
Python
Java
Aşağıdaki komutu Dockerfile'ınızı içeren dizinden çalıştırarak Cloud Build kullanarak container görüntünüzü oluşturun:
gcloud builds submit --tag gcr.io/PROJECT_ID/helloworld
İşlem başarılı olduğunda, resim adını içeren bir BAŞARILI mesajı görürsünüz
(gcr.io/PROJECT_ID/helloworld
).
Kapsayıcı resmi artık Artifact Registry içinde depolanır ve istenirse yeniden kullanılabilir.
Cloud Build yerine, kapsayıcınızı yerel olarak oluşturmak için yerel olarak yüklenmiş bir Docker sürümünü kullanabileceğinizi unutmayın.
3. adım: Kapsayıcı resmini Cloud Run'ye 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ğrulanmayan çağrılara izin ver'i
Y
yanıtlayın.
- Bir bölge seçin (örneğin
Dağıtımın tamamlanması için birkaç dakika bekleyin. Başarılı olursa komut satırında hizmet URL'si gösterilir. Örneğin:
https://helloworld-RANDOM_HASH-us-central1.a.run.app Bir web tarayıcısında hizmet URL'sini açarak dağıtılan kapsayıcınızı ziyaret edin.
Bir sonraki adımda, bu kapsüllenmiş uygulamaya Firebase Hosting URL'sinden nasıl erişeceğiniz açıklanmaktadır. Böylece uygulama, Firebase'de barındırılan siteniz için dinamik içerik oluşturabilir.
4. adım: Barındırma isteklerini container mimarisine alınmış uygulamanıza yönlendirin
Yeniden yazma kurallarıyla, belirli kalıplarla eşleşen istekleri tek bir hedefe yönlendirebilirsiniz.
Aşağıdaki örnekte, Hosting sitenizdeki /helloworld
sayfasından gelen tüm isteklerin, helloworld
kapsayıcı örneğinizin başlatılmasını ve çalıştırılmasını nasıl tetikleyeceği gösterilmektedir.
Aşağıdaki koşulların karşılandığından emin olun:
Firebase CLI'nın en son sürümüne sahip olmalısınız.
Firebase Hosting özelliğini başlattınız.
CLI'yı yükleme ve Hosting'ı başlatma hakkında ayrıntılı talimatlar için Hosting'ı Kullanmaya Başlama Kılavuzu'na bakın.
firebase.json
dosyanızı açın.rewrite
bölümünün altına aşağıdakihosting
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) } } ] }
Aşağıdaki komutu proje dizininizin kökünden çalıştırarak barındırma yapılandırmanızı sitenize dağıtın:
firebase deploy --only hosting
Kapsayıcınıza artık aşağıdaki URL'ler üzerinden erişilebilir:
Firebase alt alanlarınız:
PROJECT_ID.web.app/
vePROJECT_ID.firebaseapp.com/
Bağlı tüm özel alanlar:
CUSTOM_DOMAIN/
Hosting yapılandırma sayfasını ziyaret ederek yeniden yazma kuralları hakkında daha fazla bilgi edinin. Ayrıca, çeşitli Hosting yapılandırmaları için yanıtların öncelik sırası hakkında da bilgi edinebilirsiniz.
Yerel olarak test etme
Geliştirme sırasında container görüntünüzü yerel olarak çalıştırıp test edebilirsiniz. Ayrıntılı talimatlar için Cloud Run belgelerini ziyaret edin.
Sonraki adımlar
Dinamik içeriğinizin önbelleğe alınmasını ayarlayın.
Firebase Admin SDK'yı kullanarak diğer Firebase hizmetleriyle etkileşim kurun.
Cloud Run hakkında daha fazla bilgi edinin. Örneğin, kapsayıcıları ayarlama, yönetme ve yapılandırma ile ilgili ayrıntılı nasıl yapılır kılavuzları.
Cloud Run için fiyatlandırma ile kotalar ve sınırlar başlıklı makaleleri inceleyin.