Bu kılavuzda, Vertex AI Gemini API'a sunucu tarafı çağrılar yapmak için sunucu tarafı Remote Config ile 2. nesil Cloud Functions kullanmaya nasıl başlayacağınız açıklanmaktadır.
Bu eğiticide, chatbot benzeri bir işleve Remote Config kullanıcı sorularını yanıtlamak için Gemini modelini kullanır. Remote Config, Gemini API girişlerini (gelen kullanıcı sorgularına ekleyeceğiniz istem dahil) yönetir ve bu girişleri Firebase konsolundan isteğe bağlı olarak güncelleyebilirsiniz. İşlevi test etmek ve hata ayıklamak için de Firebase Local Emulator Suite'ü kullanırsınız. Ardından, çalıştığını doğruladıktan sonra Google Cloud'te dağıtıp test edersiniz.
Ön koşullar
Bu kılavuzda, uygulama geliştirmek için JavaScript'i kullanma konusunda bilgi sahibi olduğunuz varsayılmaktadır.
Firebase projesi oluşturun
Firebase projeniz yoksa:
Firebase konsolunda oturum açın.
Proje oluştur'u tıklayın ve aşağıdaki seçeneklerden birini kullanın:
- 1. seçenek: "Proje oluştur" iş akışının ilk adımına yeni bir proje adı girerek yeni bir Firebase projesi (ve otomatik olarak temel Google Cloud projesi) oluşturun.
- 2. Seçenek: "Proje oluştur" iş akışının ilk adımındaki açılır menüden Google Cloud proje adınızı seçerek mevcut bir Google Cloud projesine "Firebase ekleyin".
İstendiğinde, kullanmak için Google Analytics uygulamasını ayarlamanız gerekmez çözmüştük.
Projenizi oluşturmak için ekrandaki talimatları uygulamaya devam edin.
Zaten bir Firebase projeniz varsa:
Geliştirme ortamınızı yapılandırma bölümüne geçin.
Geliştirme ortamınızı yapılandırma
İşlev yazmak için Node.js ortamına ihtiyacınız vardır ve İşlevleri Cloud Functions uygulamasına dağıtmak için Firebase KSA'yı kullanmanız gerekir. belirler.
-
Node.js ve npm'yi yüklemek için Node Version Manager'ı kullanmanızı öneririz.
Tercih ettiğiniz yöntemi kullanarak Firebase CLI'yi yükleyin. Örneğin, npm kullanarak KSA'yı yüklemek için komut:
npm install -g firebase-tools@latest
Bu komut, dünya genelinde kullanılabilen
firebase
komutunu yükler. Bu komut başarısız olursa npm izinlerini değiştirmeniz gerekebilir.firebase-tools
uygulamasının en son sürümüne güncellemek için aynı komutu yeniden çalıştırın.firebase-functions
vefirebase-admin
yükleyin,--save
uygulamasını kullanarak tasarruf edinpackage.json
cihazınıza aktarın:npm install firebase-functions@latest firebase-admin@latest --save
Artık bu çözümün uygulanması işlemine devam etmeye hazırsınız.
Uygulama
2. nesil Cloud Functions'ünüzü Remote Config ve Vertex AI ile oluşturmak, test etmek ve dağıtmak için aşağıdaki adımları uygulayın:
- Google Cloud konsolunda Vertex AI önerilen API'lerini etkinleştirin.
- Projenizi başlatın ve Node bağımlılıklarını yükleyin.
- Admin SDK hizmet hesabınız için IAM izinlerini yapılandırın ve Anahtarınızı kaydedin.
- İşlevi oluşturun.
- Severe özgü bir Remote Config şablonu oluşturun.
- Fonksiyonunuzu dağıtın ve Firebase Local Emulator Suite değerleridir.
- Fonksiyonunuzu Google Cloud ürününe dağıtın.
1. adım: Vertex AI konsolunda Google Cloud önerilen API'leri etkinleştirin
- Google Cloud konsolunu açın ve istendiğinde projenizi seçin.
- Konsolun üst kısmındaki Arama alanına şunu girin: Vertex AI düğmesini tıklayın ve sonuç olarak Vertex AI değerinin görünmesini bekleyin.
- Vertex AI simgesini seçin. Vertex AI kontrol paneli görüntülenir.
Enable All Recommended APIs'ı (Önerilen Tüm API'leri Etkinleştir) tıklayın.
API etkinleştirme işleminin tamamlanması birkaç dakika sürebilir. Etkinleştirme işlemi tamamlanana kadar sayfayı etkin ve açık tutun.
Faturalandırma etkin değilse bir Cloud Billing hesapları. Faturalandırma hesabını etkinleştirdikten sonra Vertex AI kontrol paneline dönün ve önerilen tüm API'lerin etkin olduğunu doğrulayın.
2. Adım: Projenizi başlatın ve Düğüm bağımlılıklarını yükleyin
- Bilgisayarınızda bir terminal açın ve işlevinizi oluşturmayı planladığınız dizine gidin.
Firebase'e giriş yapın:
firebase login
Cloud Functions for Firebase uygulamasını başlatmak için aşağıdaki komutu çalıştırın:
firebase init functions
Mevcut bir projeyi kullan'ı seçin ve proje kimliğinizi belirtin.
Kullanılacak dili seçmeniz istendiğinde JavaScript'i seçin ve Enter tuşuna basın.
Diğer tüm seçenekler için varsayılanları belirleyin.
Geçerli dizinde bir
functions
dizini oluşturulur. İç kısımda işlevinizi geliştirmek için kullanacağınız birindex.js
dosyası bulun, fonksiyonunuzun bağımlılıklarını içeren birnode_modules
dizini, Ayrıca, paket bağımlılıklarını içeren birpackage.json
dosyası da bulunur.Aşağıdaki komutları çalıştırarak Admin SDK ve Vertex AI paketlerini ekleyin.
--save
dosyasınıpackage.json
dosyanıza kaydettiğinizden emin olmak için kullanın:cd functions npm install firebase-admin@latest @google-cloud/vertexai --save
functions/package.json
dosyanız artık aşağıdaki gibi görünecektir:
en son sürüm belirtildi:
{
"name": "functions",
"description": "Cloud Functions for Firebase",
"scripts": {
"serve": "firebase emulators:start --only functions",
"shell": "firebase functions:shell",
"start": "npm run shell",
"deploy": "firebase deploy --only functions",
"logs": "firebase functions:log"
},
"engines": {
"node": "20"
},
"main": "index.js",
"dependencies": {
"@google-cloud/vertexai": "^1.1.0",
"firebase-admin": "^12.1.0",
"firebase-functions": "^5.0.0"
},
"devDependencies": {
"firebase-functions-test": "^3.1.0"
},
"private": true
}
ESLint kullanıyorsanız, bu ifadeyi içeren bir dize göreceğinize dikkat edin. İçinde
ek olarak, düğüm motoru sürümünün yüklü
sürümünüzle eşleştiğinden emin olun.
Node.js ve nihai olarak Google Cloud üzerinde çalıştırdığınız sürüm. Örneğin,
package.json
içindeki engines
dize, Düğüm sürüm 18 olarak yapılandırılmış ve
Node.js 20 kullanıyorsanız dosyayı 20 kullanacak şekilde güncelleyin:
"engines": {
"node": "20"
},
3. Adım: Admin SDK hizmet hesabınız için IAM izinlerini yapılandırın ve anahtarınızı kaydedin
Bu çözümde, işlevinizi çalıştırmak için Firebase Admin SDK hizmet hesabını kullanacaksınız.
- Google Cloud konsolunda IAM ve Yönetici sayfasını açın ve Admin SDK hizmet hesabını (
firebase-adminsdk
adlı) bulun. - Hesabı seçin ve Ana hesabı düzenle'yi tıklayın. Erişimi düzenleme sayfası görünür.
- Başka bir rol ekle'yi tıklayın, Remote Config Görüntüleyen'i seçin.
- Başka bir rol ekle'yi tıklayın, Yapay zeka platformu geliştiricisi'ni seçin.
- Başka bir rol ekle'yi tıklayıp Vertex AI kullanıcı'yı seçin.
- Başka rol ekle'yi tıklayın, Cloud Run Çağırıcı'yı seçin.
- Kaydet'i tıklayın.
Ardından, Admin SDK hizmet hesabının kimlik bilgilerini dışa aktarın ve GOOGLE_APPLICATION_CREDENTIALS
ortam değişkeninize kaydedin.
- Google Cloud konsolunda Credentials (Kimlik bilgileri) sayfasını ziyaret edin.
- Ayrıntılar sayfasını açmak için Admin SDK hizmet hesabını tıklayın.
- Anahtarlar'ı tıklayın.
- Anahtar ekle > Yeni anahtar oluştur'u tıklayın.
- Anahtar türü olarak JSON'nin seçildiğinden emin olduktan sonra Oluştur'u tıklayın.
- Anahtarı bilgisayarınızdaki güvenli bir yere indirin.
Terminalinizden anahtarı ortam değişkeni olarak dışa aktarın:
export GOOGLE_APPLICATION_CREDENTIALS="/path/to/your/service-account-key.json"
4. Adım: İşlevi oluşturun
Bu adımda, kullanıcı girişini işleyen ve yeni oluşturulan Yapay zeka destekli yanıtlar. Admin SDK ve Vertex AI Gemini API'ü başlatan, Remote Config kullanarak varsayılan parametreleri yapılandıran, en son Remote Config parametrelerini getiren, kullanıcı girişini işleyen ve kullanıcıya yanıt aktaran kapsamlı bir işlev oluşturmak için birden fazla kod snippet'ini birleştirirsiniz.
- Kod tabanınızda,
functions/index.js
dosyasını bir metin düzenleyicide veya IDE'de açın. Mevcut içeriği silin ve ardından Admin SDK ekleyin. Remote Config ve Vertex AI SDK'sını kullanıp uygulamayı şu şekilde başlatın: aşağıdaki kodu dosyaya yapıştırın:
const { onRequest } = require("firebase-functions/v2/https"); const logger = require("firebase-functions/logger"); const { initializeApp } = require("firebase-admin/app"); const { VertexAI } = require('@google-cloud/vertexai'); const { getRemoteConfig } = require("firebase-admin/remote-config"); // Set and check environment variables. const project = process.env.GCLOUD_PROJECT; // Initialize Firebase. const app = initializeApp();
İşleviniz Remote Config sunucusuna bağlanamazsa kullanacağı varsayılan değerleri yapılandırın. Bu çözüm,
textModel
,generationConfig
,safetySettings
,textPrompt
velocation
parametrelerini bu kılavuzun ilerleyen bölümlerinde yapılandıracağınız Remote Config parametreleriyle eşleşen Remote Config parametreleri olarak yapılandırır. Bu parametreler hakkında daha fazla bilgi için Vertex AI Node.js istemcisi başlıklı makaleyi inceleyin.İsteğe bağlı olarak, bir izleme kodu kullanıp kullanmayacağınızı kontrol etmek için Vertex AI Gemini API parametresine (bu örnekte
vertex_enabled
) tıklayın. Bu kurulum, işlevinizi test ederken yararlı olabilir. Aşağıdaki kod snippet'lerinde bu değerfalse
olarak ayarlanmıştır. Bu durumda, temel işlev dağıtımını test ederken Vertex AI kullanımı atlanır. Şu şekilde ayarlanıyor:true
, Vertex AI Gemini API yöntemini çağırır.// Define default (fallback) parameter values for Remote Config. const defaultConfig = { // Default values for Vertex AI. model_name: "gemini-1.5-flash-preview-0514", generation_config: [{ "stopSequences": [], "temperature": 0.7, "maxOutputTokens": 64, "topP": 0.1, "topK": 20 }], prompt: "I'm a developer who wants to learn about Firebase and you are a \ helpful assistant who knows everything there is to know about Firebase!", safety_settings: [{ "category": "HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT", "threshold": "HarmBlockThreshold.BLOCK_MEDIUM_AND_ABOVE" }], location: 'us-central1', // Disable Vertex AI Gemini API access for testing. vertex_enabled: false };
İşlevi oluşturun ve sunucu tarafı Remote Config ayarlayın:
// Export the function. exports.generateWithVertex = onRequest(async (request, response) => { try { // Set up Remote Config. const rc = getRemoteConfig(app); // Get the Remote Config template and assign default values. const template = await rc.getServerTemplate({ defaultConfig: defaultConfig }); // Add the template evaluation to a constant. const config = template.evaluate(); // Obtain values from Remote Config. const textModel = config.getString("model_name") || defaultConfig.model_name; const textPrompt = config.getString("prompt") || defaultConfig.prompt; const generationConfig = config.getString("generation_config") || defaultConfig.generation_config; const safetySettings = config.getString("safety_settings") || defaultConfig.safety_settings; const location = config.getString("location") || defaultConfig.location; const vertexEnabled = config.getBoolean("is_vertex_enabled") || defaultConfig.vertex_enabled;
Vertex AI özelliğini ayarlayıp sohbet ve yanıt mantığını ekleyin:
// Allow user input. const userInput = request.query.prompt || ''; // Instantiate Vertex AI. const vertex_ai = new VertexAI({ project: project, location: location }); const generativeModel = vertex_ai.getGenerativeModel({ model: textModel, safety_settings: safetySettings, generation_config: generationConfig, }); // Combine prompt from Remote Config with optional user input. const chatInput = textPrompt + " " + userInput; if (!chatInput) { return res.status(400).send('Missing text prompt'); } // If vertexEnabled isn't true, do not send queries to Vertex AI. if (vertexEnabled !== true) { response.status(200).send({ message: "Vertex AI call skipped. Vertex is not enabled." }); return; } logger.log("\nRunning with model ", textModel, ", prompt: ", textPrompt, ", generationConfig: ", generationConfig, ", safetySettings: ", safetySettings, " in ", location, "\n"); const result = await generativeModel.generateContentStream(chatInput); response.writeHead(200, { 'Content-Type': 'text/plain' }); for await (const item of result.stream) { const chunk = item.candidates[0].content.parts[0].text; logger.log("Received chunk:", chunk); response.write(chunk); } response.end(); } catch (error) { logger.error(error); response.status(500).send('Internal server error'); } });
Dosyayı kaydedip kapatın.
5. adım: Sunucuya özel bir Remote Config şablonu oluşturun
Sonra, sunucu tarafı bir Remote Config şablonu oluşturun ve parametreleri yapılandırın değerleri girin. Sunucuya özgü bir şablon oluşturmak için:
- Firebase konsolunu açın ve gezinme menüsünde Çalıştır'ı tıklayıp seçin Remote Config.
Sayfanın üst kısmındaki İstemci/Sunucu seçicisinden Sunucu'yu seçinRemote Config.
- Remote Config veya sunucu şablonlarını ilk kez kullanıyorsanız Yapılandırma Oluştur'u tıklayın. İlk sunucu tarafı parametrenizi oluşturun bölmesi görünür.
- Remote Config sunucu şablonlarını ilk kez kullanmıyorsanız Parametre ekle'yi tıklayın.
Şu Remote Config parametrelerini tanımlayın:
Parametre adı Açıklama Tür Varsayılan değer model_name
Model adı
Kodunuzda kullanılacak model adlarının güncel listeleri için Model sürümleri ve yaşam döngüleri veya Kullanılabilir model adları başlıklı makalelere bakın.Dize gemini-1.5-pro-preview-0514
prompt
Kullanıcının sorgusuna eklenecek metni isteyin. Dize I'm a developer who wants to learn about Firebase and you are a helpful assistant who knows everything there is to know about Firebase!
generation_config
Parametreler anahtar değerleri modele gönderebilirsiniz. JSON [{"stopSequences": ["I hope this helps"],"temperature": 0.7,"maxOutputTokens": 512, "topP": 0.1,"topK": 20}]
safety_settings
Vertex AI için güvenlik ayarları JSON [{"category": "HarmCategory.HARM_CATEGORY_DANGEROUS_CONTENT", "threshold": "HarmBlockThreshold.BLOCK_LOW_AND_ABOVE"}]
location
Vertex AI hizmetini ve modelini çalıştırmak için konum izni Dize us-central1
is_vertex_enabled
Sorguların Vertex AI adresine gönderilip gönderilmeyeceğini kontrol eden isteğe bağlı parametre. Boole true
Parametre eklemeyi bitirdiğinizde parametrelerinizi ve veri türlerinin doğru olup olmadığını tekrar kontrol edin, ardından Değişiklikleri yayınla'yı tıklayın.
6. Adım: İşlevinizi dağıtın ve Firebase Local Emulator Suite içinde test edin
Artık işlevinizi Firebase Local Emulator Suite ile yerel olarak dağıtmaya ve test etmeye hazırsınız.
GOOGLE_APPLICATION_CREDENTIALS
ortamını ayarladığınızdan emin olun değişkeni 3. Adım: Öğenizin IAM izinlerini yapılandırın ve Admin SDK hizmet hesabı oluşturun ve tuşu. Ardından,functions
dizininizin ana dizini üzerinde çalışıyorsanız, işlevinizi Firebase emülatörü:firebase emulators:start --project PROJECT_ID --only functions
Emülatörün günlükler sayfasını açın. Bu, fonksiyonunuzun yüklendiğini göstermelidir.
Aşağıdaki komutu çalıştırarak işlevinize erişin. Bu komutta PROJECT_ID proje kimliğiniz, LOCATION ise işlevi dağıttığınız bölgedir (örneğin,
us-central1
):curl http://localhost:5001/PROJECT_ID/LOCATION/generateWithVertex
Yanıt bekleyin, ardından Firebase Emulator günlükleri sayfasına dönün veya konsolu ve hata veya uyarı olup olmadığını kontrol edin.
is_vertex_enabled
, Remote Config sunucu şablonunuzda yapılandırıldığı için Vertex AI Gemini API üzerinden Gemini'ye erişmesi gerektiğini ve bunun ücretlendirilebileceğini göz önünde bulundurarak bazı kullanıcı girişleri göndermeyi deneyin:curl http://localhost:5001/PROJECT_ID/LOCATION/generateWithVertex?prompt=Tell%20me%20everything%20you%20know%20about%20cats
Firebase konsolunda Remote Config sunucu şablonunuzda değişiklik yapın, ardından değişiklikleri gözlemlemek için işlevinize yeniden erişin.
7. adım: İşlevinizi Google Cloud'e dağıtın
İşlevinizi test edip doğruladıktan sonra Google Cloud ve canlı işlevi test edin.
İşlevinizi dağıtma
Firebase KSA'yı kullanarak işlevinizi dağıtın:
firebase deploy --only functions
İşleve kimlik doğrulaması yapılmamış erişimi engelleme
İşlevler Firebase kullanılarak dağıtıldığında, kuruluşunuzun politikası bunu kısıtlamıyorsa kimlik doğrulaması yapılmayan çağrılara varsayılan olarak izin verilir. Test sırasında ve App Check ile güvenliği sağlamadan önce kimlik doğrulaması yapılmamış erişimi engellemenizi öneririz.
İşleve kimlik doğrulaması yapılmamış erişimi engellemek için:
Google Cloud konsolunda Cloud Run'u açın.
generateWithVertex
simgesini ve ardından Güvenlik sekmesini tıklayın.Kimlik doğrulama gerektir'i etkinleştirin ve ardından Kaydet'i tıklayın.
Kullanıcı hesabınızı, Admin SDK hizmet hesabı kimlik bilgilerini kullanacak şekilde yapılandırın
Admin SDK hizmet hesabı, işlevi çalıştırmak ve Remote Config ile Vertex AI Gemini API ile etkileşimde bulunmak için gerekli tüm rollere ve izinlere sahip olduğundan işlevinizi çalıştırmak için bu hesabı kullanmanız gerekir. Bunu yapmak için kullanıcı hesabınızdan hesap için jeton oluşturabilmeniz gerekir.
Aşağıdaki adımlarda, kullanıcı hesabınızı ve Admin SDK hizmet hesabı ayrıcalıklarıyla çalışacak işlevi nasıl yapılandıracağınız açıklanmaktadır.
- Google Cloud konsolunda IAM Service Account Credentials API'yi etkinleştirin.
- Kullanıcı hesabınıza Hizmet Hesabı Jetonu Oluşturucu rolünü verin: Google Cloud konsolunda IAM ve Yönetici > IAM, kullanıcınızı seçin ve ardından, Ana hesabı düzenle'yi tıklayın > Başka bir rol ekleyin.
Service Account Token Creator'ı (Hizmet Hesabı Jetonu Oluşturucu) seçip Save'i (Kaydet) tıklayın.
Hizmet hesabı kimliğine bürünme hakkında daha ayrıntılı bilgi için Google Cloud dokümanlarında Hizmet hesabı kimliğine bürünme bölümüne bakın.
Google Cloud Console Cloud Functions sayfasını açın ve İşlevler listesinde generateWithVertex işlevini tıklayın.
Tetikleyici > Düzenleyin ve genişletin Çalışma zamanı, derleme, bağlantılar ve güvenlik ayarlarını değiştirin.
Çalışma zamanı sekmesinde, Çalışma zamanı hizmet hesabını Yönetici SDK hesabı olarak değiştirin.
Sonraki'yi, ardından Dağıt'ı tıklayın.
gcloud CLI'ı kurma
İşlevinizi komut satırından güvenli bir şekilde çalıştırmak ve test etmek için Cloud Functions hizmetiyle kimlik doğrulamanız ve geçerli bir kimlik doğrulama jetonu almanız gerekir.
Jeton oluşturmayı etkinleştirmek için gcloud KSA'yı yükleyin ve yapılandırın:
Bilgisayarınızda yüklü değilse gcloud CLI'yi gcloud CLI'yi yükleme bölümünde açıklandığı şekilde yükleyin.
Google Cloud hesabınızın erişim kimlik bilgilerini edinin:
gcloud auth login
gcloud'da proje kimliğinizi ayarlayın:
gcloud config set project PROJECT_ID
İşlevinizi test etme
Artık işlevinizi Google Cloud'te test etmeye hazırsınız. İşlevi test etmek için aşağıdaki komutu çalıştırın:
curl -X POST https://LOCATION-PROJECT_ID.cloudfunctions.net/generateWithVertex \
-H "Authorization: bearer $(gcloud auth print-identity-token)" \
-H "Content-Type: application/json"
Kullanıcı tarafından sağlanan verilerle tekrar deneyin:
curl -X POST https://LOCATION-PROJECT_ID.cloudfunctions.net/generateWithVertex?prompt=Tell%20me%20everything%20you%20know%20about%20dogs \
-H "Authorization: bearer $(gcloud auth print-identity-token)" \
-H "Content-Type: application/json"
Artık Remote Config sunucu şablonunuzda değişiklik yapabilir, yayınlayabilirsiniz ve farklı seçenekleri test edebilirsiniz.
Sonraki adımlar
- Firebase, güvenliği sağlamak için App Check kullanmanızı önerir Cloud Functions. Şunlar için App Check yaptırımını etkinleştirme: Cloud Functions App Check ile işlevinizin güvenliğini sağlama hakkında daha fazla bilgi
- Sunucu tarafı Remote Config ile örnek bir çağrılabilir işlevi deneyin ve Yer: App Check Vertex AI Gemini API numaralı telefonu Remote Config ile arayın ve App Check.
- Şu hizmetler için Cloud Functions hakkında daha fazla bilgi edinin: Firebase'i seçin.
- Remote Config'u sunucu ortamlarında kullanma hakkında daha fazla bilgi edinin.