Dinamik içeriğinizi oluşturmak ve sunmak veya mikro hizmetler olarak REST API'leri oluşturmak için Cloud Run'ı Firebase Hosting ile eşleştirin.
Kullanımı Bulut Çalıştır , bir konteyner görüntüde paketlenmiş bir uygulama dağıtabilir. Ardından, Firebase Hosting'i kullanarak kapsayıcılı uygulamanızı tetiklemek için HTTPS isteklerini yönlendirebilirsiniz.
- Bulut Run destekler birçok dil size istediğiniz programlama dilini ve çerçevesini kullanma esnekliği tanıyan, (Go, node.js, Python ve Java dahil).
- Bulut çalıştırın otomatik ve yatay olarak ölçekler sonra, alınan istekleri işlemek için konteyner görüntü talebi azaldığında aşağı ölçekler.
- Yalnızca ödeme işlemci, bellek için ve istek işleme sırasında tüketilen ilişki ağlarını.
Firebase Hosting ile entegre Bulut Koşusu için örnek kullanım durumları ve numuneler için, bizim ziyaret Sunucusuz bakış .
Bu kılavuz size şunları nasıl yapacağınızı gösterir:
- Basit bir Merhaba Dünya uygulaması yazın
- Bir uygulamayı container mimarisine alın ve Container Registry'ye yükleyin
- Kapsayıcı görüntüsünü Cloud Run'a dağıtın
- Kapsayıcılı uygulamanıza doğrudan Barındırma istekleri
Yapabilirsiniz isteğe ayar dinamik içerik sunan performansını artırmak için Not önbellek ayarları .
Sen başlamadan önce
Bulut Çalıştır kullanmadan önce, bir bulut Fatura hesap oluştururken Bulut Run API sağlayan ve yükleme gibi bazı ilk görevleri tamamlamak için gereken gcloud
komut satırı aracı.
Projeniz için faturalandırmayı ayarlayın
Bulut Run sunmaktadır ücretsiz kullanım kotasını , ama yine de bir olmalıdır Bulut Fatura hesabı şekilde kullanmak için Firebase projeyle ilişkili veya Cloud Run deneyin.
API'yi etkinleştirin ve SDK'yı yükleyin
Google API konsolunda Cloud Run API'yi etkinleştirin:
Aç Bulut Run API sayfasını Google API konsolunda.
İstendiğinde, Firebase projenizi seçin.
Tıklayın Bulut Run API sayfasına etkinleştirin.
Yükleme ve başlatmak Bulut SDK.
Kontrol edin
gcloud
aracı doğru proje için yapılandırılır:gcloud config list
Adım 1: Örnek uygulamayı yaz
Bulut Run desteklediğini Not birçok dili aşağıdaki örnekte gösterildiği dillere ek olarak.
Gitmek
Yeni bir dizin adında oluşturun
helloworld-go
içine, o zaman değişim dizini:mkdir helloworld-go
cd helloworld-go
Yeni bir dosya adı oluşturun
helloworld.go
, sonra aşağıdaki kodu ekleyin:Bu kod bağlantı noktasında dinler tarafından tanımlanan bu temel bir web sunucusu oluşturur
PORT
ortam değişkeni.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
Node.js
Adlı yeni bir dizin oluşturun
helloworld-nodejs
içine, ardından değişim dizini:mkdir helloworld-nodejs
cd helloworld-nodejs
Bir oluşturun
package.json
aşağıdaki içeriği ile dosyayı:Adlı yeni bir dosya oluşturun
index.js
, sonra aşağıdaki kodu ekleyin:Bu kod bağlantı noktasında dinler tarafından tanımlanan bu temel bir web sunucusu oluşturur
PORT
ortam değişkeni.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
piton
Yeni bir dizin adında oluşturun
helloworld-python
içine, ardından değişim dizini:mkdir helloworld-python
cd helloworld-python
Adlı yeni bir dosya oluşturun
app.py
, sonra aşağıdaki kodu ekleyin:Bu kod bağlantı noktasında dinler tarafından tanımlanan bu temel bir web sunucusu oluşturur
PORT
ortam değişkeni.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
Java
Yükleme Java SE 8 veya daha yeni JDK ve CURL .
Bunu yalnızca bir sonraki adımda yeni web projesini oluşturmak için 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 ve 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.
Güncelleme
SpringBootApplication
sınıfısrc/main/java/com/example/helloworld/HelloworldApplication.java
bir ekleyerek@RestController
işlemek için/
haritalama ve ayrıca eklemek@Value
sağlamak üzere alanınıTARGET
ortam değişkeni:Bu kod bağlantı noktasında dinler tarafından tanımlanan bu temel bir web sunucusu oluşturur
PORT
ortam değişkeni.
Uygulamanız tamamlandı ve kapsayıcıya alınmaya ve Container Registry'ye yüklenmeye hazır.
2. Adım: ambalajlamasını bir uygulama ve Konteyner Sicil yükleyin
Adlı yeni bir dosya oluşturarak örnek uygulamayı ambalajlamasını
Dockerfile
kaynak dosyaları ile aynı dizinde. 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ılı olduktan sonra, 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 saklanmaktadır ve istenirse yeniden kullanılabilir.
Yerine Bulut Build yapmanız Docker bir yerel olarak yüklü sürümünü kullanabilirsiniz, unutmayın yerel Kapsayıcınızı inşa .
3. Adım: Bulut Çalıştır konteyner görüntü dağıtma
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ı onayla (örneğin,
helloworld
) - Yanıt
Y
için , kimlik doğrulaması etkinleştirilmelerinde izin
- 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 sizin Firebase barındırılan site için dinamik içerik oluşturmak, böylece bir Firebase Hosting URL'den bu konteynerle uygulamaya erişmek için size yol gösterir.
4. Adım: konteynerle app doğrudan barındırma istekleri
İle , yeniden yazma kuralları , tek bir hedefe belirli kalıplarla eşleşen istekleri yönlendirebilir.
Sayfa tüm isteklerini yönlendirmek için nasıl Aşağıdaki örnek gösterir /helloworld
senin Hosting sitesinde başlangıç tetikleyebilir ve koşu için helloworld
konteyner örneği.
Emin olun:
Sen var Firebase CLI son sürümünü .
Firebase Hosting'i başlattınız.
CLI yükleme ve Barındırma başlatılıyor hakkında ayrıntılı talimatlar için bkz Hosting için Başlayın kılavuzuna .
Senin açın
firebase.json
dosyasını .Aşağıdaki ekleyin
rewrite
altında yapılandırmayıhosting
bölümünde:"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) } } ] }
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
Kapsayıcınıza artık aşağıdaki URL'ler aracılığıyla erişilebilir:
Firebase alt alanlarınız:
PROJECT_ID .web.app/
vePROJECT_ID .firebaseapp.com/
Herhangi bağlı özel alanlar :
CUSTOM_DOMAIN /
İçin barındırma yapılandırma sayfasını ziyaret edin yeniden yazma kuralları hakkında daha fazla ayrıntı . Ayrıca öğrenebilir yanıtların öncelik sırasına çeşitli Barındırma yapılandırmalar için.
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, ziyaret Bulut Run belgelerine .
Sonraki adımlar
Önbelleğe kurun küresel CDN üzerinde dinamik içerik.
Etkileşim kullanan diğer Firebase hizmetlerle Firebase Yönetici SDK'yı .
Dahil Bulut Run hakkında daha fazla bilgi ayrıntılı nasıl yapılır kılavuzları , kurma, yönetme ve konteyner yapılandırmak için.
Gözden fiyatlandırma ve kotaları ve limitleri Bulut Run için.