Gdy używasz szablonów promptów serwera, możesz aktualizować wartości w danym szablonie bez publikowania nowej wersji aplikacji. Ponieważ jednak wszelkie zmiany w szablonie będą niemal natychmiast wykorzystywane przez żądania z aplikacji, musisz uważać, aby nie wprowadzać zmian, które mogłyby spowodować awarię aplikacji lub nieoczekiwane zmiany w jej działaniu.
Jeśli chcesz wprowadzić większe zmiany lub wdrażać je stopniowo, nie zmieniaj szablonu używanego w kodzie produkcyjnym.
Zamiast tego zalecamy używanie Firebase Remote Config do kontrolowania wartości identyfikatora szablonu używanego w żądaniu do modelu.
Firebase Remote Config umożliwia dynamiczne i zdalne aktualizowanie wartości parametrów w aplikacji (np. identyfikatora szablonu) z poziomu Firebase konsoli bez konieczności publikowania nowej wersji aplikacji. Ma też uproszczone funkcje i integracje do wdrażania zmian oraz testów A/B.
, nawet podczas jej tworzenia, aby móc zdalnie aktualizować identyfikator szablonu w każdej wersji aplikacji.Z tego przewodnika dowiesz się, jak zaimplementować Remote Config w aplikacji, aby kontrolować identyfikator szablonu używany w aplikacji.
Krok 1. Ustaw wartość parametru w konsoli Firebase
Utwórz szablon klienta Remote Config i skonfiguruj parametr template_id
oraz jego wartość, aby pobierać i używać go w aplikacji.
W konsoli Firebase otwórz DevOps i zaangażowanie > Zdalna konfiguracja.
U góry strony w selektorze Klient/serwer kliknij Klient.
Rozpocznij tworzenie szablonu klienta, klikając Utwórz konfigurację (lub Dodaj parametr , jeśli wcześniej używałeś szablonów klienta).
Zdefiniuj parametr
template_id:Nazwa parametru Opis Typ Wartość domyślna template_idIdentyfikator szablonu. Ciąg znaków my-first-template-v1-0-0Po dodaniu tego parametru kliknij Opublikuj zmiany. Jeśli nie jest to nowy szablon Remote Config, sprawdź zmiany i ponownie kliknij Opublikuj zmiany.
Krok 2. Dodaj i zainicjuj Remote Config w aplikacji
Dodaj bibliotekę Remote Config i skonfiguruj ją w aplikacji.Remote Config
Swift
W ramach Firebase AI Logic konfiguracji, pakiet SDK Firebase został już dodany do aplikacji, ale musisz też dodać Remote Config.
Po otwarciu projektu w Xcode kliknij File > Add Package Dependencies (Plik > Dodaj zależności pakietu).
Kliknij firebase-ios-sdk , a potem Add package (Dodaj pakiet).
W nawigatorze projektu kliknij kolejno aplikację > Targets (Cele) > aplikację.
Na karcie General (Ogólne) przewiń do sekcji Frameworks, Libraries, and Embedded Content (Frameworki, biblioteki i treści osadzone).
Kliknij + i wybierz FirebaseRemoteConfig, a potem kliknij Add.
Dodaj do kodu instrukcję importu
FirebaseRemoteConfig:import FirebaseRemoteConfigW odpowiedniej klasie aplikacji zainicjuj Firebase i dodaj Remote Config do głównej logiki aplikacji.
W tym miejscu dodasz Remote Config i Remote Config odbiornik w czasie rzeczywistym jako instrukcje importu, aby aplikacja mogła pobierać nowe wartości w czasie rzeczywistym, oraz dodasz minimalny interwał pobierania:
let remoteConfig = RemoteConfig.remoteConfig() let settings = RemoteConfigSettings() settings.minimumFetchInterval = 3600 remoteConfig.configSettings = settings
Kotlin
Dodaj zależność Remote Config do pliku Gradle modułu (na poziomie aplikacji) (zwykle
app/build.gradle.ktslubapp/build.gradle):dependencies { implementation(platform("com.google.firebase:firebase-bom:34.13.0")) implementation("com.google.firebase:firebase-ai") implementation("com.google.firebase:firebase-config") // ... other dependencies }Dodaj Remote Config do głównej logiki aplikacji. W tym miejscu zainicjujesz Remote Config i dodasz minimalny interwał pobierania:
val remoteConfig: FirebaseRemoteConfig = Firebase.remoteConfig val configSettings = remoteConfigSettings { minimumFetchIntervalInSeconds = 3600 } remoteConfig.setConfigSettingsAsync(configSettings)
Java
Dodaj zależność Remote Config do pliku Gradle modułu (na poziomie aplikacji) (zwykle
app/build.gradle.ktslubapp/build.gradle):dependencies { implementation(platform("com.google.firebase:firebase-bom:34.13.0")) implementation("com.google.firebase:firebase-ai") implementation("com.google.firebase:firebase-config") // ... other dependencies }Dodaj Remote Config do głównej logiki aplikacji. W tym miejscu zainicjujesz Remote Config i dodasz minimalny interwał pobierania:
FirebaseRemoteConfig mFirebaseRemoteConfig = FirebaseRemoteConfig.getInstance(); FirebaseRemoteConfigSettings configSettings = new FirebaseRemoteConfigSettings.Builder() .setMinimumFetchIntervalInSeconds(3600) .build(); mFirebaseRemoteConfig.setConfigSettingsAsync(configSettings);
Web
Otwórz kod w edytorze tekstu i zaimportuj Remote Config:
import { getRemoteConfig } from 'firebase/remote-config';W funkcji głównej i po zainicjowaniu aplikacji w Firebase na potrzeby pakietu SDK Firebase AI Logic zainicjuj Remote Config:
// Initialize Remote Config and get a reference to the service const remoteConfig = getRemoteConfig(app);Ustaw minimalny interwał pobierania:
remoteConfig.settings.minimumFetchIntervalMillis = 3600000;
Dart
W katalogu projektu Flutter zainstaluj i dodaj Remote Config za pomocą tego polecenia:
flutter pub add firebase_remote_configOtwórz plik
./lib/main.darti dodaj instrukcję importu po innych instrukcjach importu, które dodano na potrzeby Firebase AI Logic:import 'package:firebase_vertexai/firebase_ai.dart'; import 'package:firebase_core/firebase_core.dart'; import 'package:firebase_remote_config/firebase_remote_config.dart';Dodaj do aplikacji zmienną
_modelName, aby móc jej później używać:late final String _modelName; late final String _systemInstructions; late final String _prompt;Pobierz obiekt Remote Config i ustaw minimalny interwał pobierania ustawień , aby umożliwić ich częste odświeżanie. Pamiętaj, aby dodać ten kod po zainicjowaniu Firebase.
final remoteConfig = FirebaseRemoteConfig.instance; await remoteConfig.setConfigSettings(RemoteConfigSettings( fetchTimeout: const Duration(seconds: 3600), minimumFetchInterval: const Duration(seconds: 3600), ));
Unity
Dodaj Remote Config do projektu Unity, postępując zgodnie z tymi instrukcjami.
Pobierz obiekt Remote Config i ustaw minimalny interwał pobierania ustawień , aby umożliwić ich częste odświeżanie. Pamiętaj, aby dodać ten kod po zainicjowaniu Firebase.
var remoteConfig = FirebaseRemoteConfig.DefaultInstance; const int MillisecondsPerSecond = 1000; await remoteConfig.SetConfigSettingsAsync(new ConfigSettings() { FetchTimeoutInMilliseconds = 3600 * MillisecondsPerSecond, MinimumFetchIntervalInMilliseconds = 3600 * MillisecondsPerSecond });
Krok 3. Ustaw wartość parametru w aplikacji
Wartości domyślne parametrów w aplikacji należy ustawić w obiekcie Remote Config. Dzięki temu aplikacja będzie działać zgodnie z oczekiwaniami, nawet jeśli nie będzie mogła pobrać wartości z usługi Remote Config.
Swift
W konsoli Firebase otwórz DevOps i zaangażowanie > Zdalna konfiguracja > Parametry.
Otwórz
Menu i kliknij Pobierz wartości domyślne.Gdy pojawi się prośba, włącz .plist na iOS, a potem kliknij Pobierz plik.
Zapisz plik w katalogu aplikacji.
W Xcode kliknij prawym przyciskiem myszy aplikację i wybierz Add Files (Dodaj pliki).
Kliknij remote_config_defaults.plist, a potem Add (Dodaj).
Zaktualizuj kod aplikacji, aby odwoływał się do pliku domyślnego:
// Set default values for Remote Config parameters. remoteConfig.setDefaults(fromPlist: "remote_config_defaults")
Kotlin
W konsoli Firebase otwórz DevOps i zaangażowanie > Zdalna konfiguracja > Parametry.
Otwórz
Menu i kliknij Pobierz wartości domyślne.Gdy pojawi się prośba, włącz .xml na Androida, a potem kliknij Pobierz plik.
Zapisz plik w katalogu zasobów XML aplikacji.
Zaktualizuj plik głównej aktywności, aby dodać wartości domyślne po dodanych wcześniej ustawieniach
configSettings:// Set default values for Remote Config parameters. remoteConfig.setDefaultsAsync(R.xml.remote_config_defaults)
Java
W konsoli Firebase otwórz DevOps i zaangażowanie > Zdalna konfiguracja > Parametry.
Otwórz
Menu i kliknij Pobierz wartości domyślne.Gdy pojawi się prośba, włącz .xml na Androida, a potem kliknij Pobierz plik.
Zapisz plik w katalogu zasobów XML aplikacji.
Zaktualizuj plik głównej aktywności, aby dodać wartości domyślne po dodanych wcześniej ustawieniach
configSettings:// Set default values for Remote Config parameters. mFirebaseRemoteConfig.setDefaultsAsync(R.xml.remote_config_defaults);
Web
Wartość domyślną nazwy modelu możesz ustawić bezpośrednio w kodzie:
// Set default values for Remote Config parameters.
remoteConfig.defaultConfig = {
template_id: 'my-first-template-v1-0-0',
};
Dart
Wartość domyślną nazwy modelu możesz ustawić bezpośrednio w kodzie:
// Set default values for Remote Config parameters.
remoteConfig.setDefaults(const {
"template_id": "my-first-template-v1-0-0"
});
Unity
Wartość domyślną nazwy modelu możesz ustawić bezpośrednio w kodzie:
// Set default values for Remote Config parameters.
await remoteConfig.SetDefaultsAsync(
new System.Collections.Generic.Dictionary<string, object>() {
{ "template_id", "my-first-template-v1-0-0" }
}
);
Krok 4. Pobierz i aktywuj wartość
Po ustawieniu wartości domyślnej nazwy modelu dodaj ten kod, aby pobrać i aktywować wartości.
Swift
// Fetch and activate Remote Config values
remoteConfig.fetchAndActivate { status, error in
if let error = error {
print("Error fetching Remote Config: \(error.localizedDescription)")
}
}
Powinno to aktualizować obiekt Remote Config za każdym razem, gdy opublikowany zostanie nowy Remote Config szablon.
Kotlin
// Fetch and activate Remote Config values
remoteConfig.fetchAndActivate()
.addOnCompleteListener(this) { task ->
if (task.isSuccessful) {
val updated = task.result
Log.d(TAG, "Remote Config values fetched and activated: $updated")
} else {
Log.e(TAG, "Error fetching Remote Config", task.exception)
}
}
Java
// Fetch and activate Remote Config values
mFirebaseRemoteConfig.fetchAndActivate()
.addOnCompleteListener(this, new OnCompleteListener<Boolean>() {
@Override
public void onComplete(@NonNull Task<Boolean> task) {
if (task.isSuccessful()) {
boolean updated = task.getResult();
Log.d(TAG, "Config params updated: " + updated);
} else {
Log.e(TAG, "Error fetching Remote Config", task.exception)
}
}
});
Web
Dodaj do instrukcji importu
getValueifetchAndActivate:import { getValue, fetchAndActivate } from 'firebase/remote-config';Znajdź kod, w którym określasz wartość domyślną nazwy modelu. Bezpośrednio po tym bloku kodu dodaj ten kod, aby pobrać i aktywować konfigurację oraz przypisać pobraną wartość do stałej
templateID.// Fetch and activate Remote Config. try { await fetchAndActivate(remoteConfig); } catch(err) { console.error('Remote Config fetch failed', err); } console.log('Remote Config fetched.'); // Assign Remote Config values. const templateID = getValue(remoteConfig, 'template_id').asString();
Dart
// Fetch and activate Remote Config.
remoteConfig.fetchAndActivate();
// Assign Remote Config values.
String? _templateID = remoteConfig.getString("template_id");
Unity
// Fetch and activate Remote Config values.
await remoteConfig.FetchAndActivateAsync();
Krok 5. Dodaj odbiornik w czasie rzeczywistym Remote Config
Dodaj do aplikacji odbiornik Zdalnej konfiguracji Remote Config w czasie rzeczywistym , aby zmiany wprowadzane w szablonie Remote ConfigZdalnej konfiguracji były przekazywane do klienta natychmiast po ich zaktualizowaniu.
Ten kod aktualizuje obiekt Remote Config za każdym razem, gdy zmieni się wartość parametru.
Swift
// Add real-time Remote Config
remoteConfig.addOnConfigUpdateListener { configUpdate, error in
guard let configUpdate = configUpdate, error == nil else {
print("Error listening for config updates: \(error?.localizedDescription ?? "No error available")")
return
}
print("Updated keys: \(configUpdate.updatedKeys)")
remoteConfig.activate { changed, error in
guard error == nil else {
print("Error activating config: \(error?.localizedDescription ?? "No error available")")
return
}
print("Activated config successfully")
}
}
Kotlin
Opcjonalnie możesz też skonfigurować działanie w ramach aktywacji addOnCompleteListener:
// Add a real-time Remote Config listener
remoteConfig.addOnConfigUpdateListener(object : ConfigUpdateListener {
override fun onUpdate(configUpdate : ConfigUpdate) {
Log.d(ContentValues.TAG, "Updated keys: " + configUpdate.updatedKeys);
remoteConfig.activate().addOnCompleteListener {
// Optionally, add an action to perform on update here.
}
}
override fun onError(error : FirebaseRemoteConfigException) {
Log.w(ContentValues.TAG, "Config update error with code: " + error.code, error)
}
}
Java
Opcjonalnie możesz też skonfigurować działanie w ramach aktywacji addOnCompleteListener:
// Add a real-time Remote Config listener
remoteConfig.addOnConfigUpdateListener(new ConfigUpdateListener() {
@Override
public void onUpdate(ConfigUpdate configUpdate) {
Log.d(ContentValues.TAG, "Updated keys: " + configUpdate.getUpdatedKeys());
remoteConfig.activate().addOnCompleteListener(new OnCompleteListener<Boolean>() {
@Override
public void onComplete(@NonNull Task<Boolean> task) {
// Optionally, add an action to perform on update here.
}
});
}
@Override
public void onError(FirebaseRemoteConfigException error) {
Log.w(ContentValues.TAG, "Config update error with code: " + error.getCode(), error);
}
});
Web
// Add a real-time Remote Config listener
onConfigUpdate(remoteConfig, {
next: (configUpdate) => {
console.log("Updated keys:", configUpdate.getUpdatedKeys());
if (configUpdate.getUpdatedKeys().has("welcome_message")) {
activate(remoteConfig).then(() => {
showWelcomeMessage();
});
}
},
error: (error) => {
console.log("Config update error:", error);
},
complete: () => {
console.log("Listening stopped.");
}
});
Dart
// Add a real-time Remote Config listener
remoteConfig.onConfigUpdated.listen((event) async {
await remoteConfig.activate();
});
Unity
// Add a real-time Remote Config listener to automatically update whenever
// a new template is published.
// Note: the parameters can be anonymous as they are unused.
remoteConfig.OnConfigUpdateListener += (_, _) => {
remoteConfig.ActivateAsync();
};
Krok 6. Zaktualizuj żądania Gemini API, aby używać wartości Remote Config
|
Kliknij dostawcę Gemini API, aby wyświetlić na tej stronie treści i kod dotyczące konkretnego dostawcy. |
Gdy Remote Config jest już w pełni skonfigurowana, zaktualizuj kod, aby zastąpić wartości zakodowane na stałe wartościami pochodzącymi ze Remote Config.
Swift
import FirebaseAI
let templateID = remoteConfig.configValue(forKey: "template_id").stringValue
let model = FirebaseAI.firebaseAI(backend: .googleAI()).templateGenerativeModel()
let customerName = "Jane"
// When making the `generateContent` call, source the template ID value from Remote Config
let response = try await model.generateContent(
templateID: templateID,
// Provide the values for any input variables required by your template.
inputs: [
"customerName": customerName
]
)
// ...
Kotlin
// ...
val model = Firebase.ai(backend = GenerativeBackend.googleAI()).templateGenerativeModel()
val customerName = "Jane"
// When making the `generateContent` call, source the template ID value from Remote Config
val response = model.generateContent(
remoteConfig.getString("template_id"),
// Provide the values for any input variables required by your template.
mapOf(
"customerName" to customerName
)
)
val text = response.text
println(text)
Java
// ...
TemplateGenerativeModel ai = FirebaseAI.getInstance()
.templateGenerativeModel(null /* Request Options */);
TemplateGenerativeModelFutures model = TemplateGenerativeModelFutures.from(ai);
String customerName = "Jane";
// When making the `generateContent` call, source the template ID value from Remote Config
Future<GenerateContentResponse> response = model.generateContent(
remoteConfig.getString("template_id"),
// Provide the values for any input variables required by your template.
mapOf("customerName", customerName)
);
addCallback(response,
new FutureCallback<GenerateContentResponse>() {
public void onSuccess(GenerateContentResponse result) {
System.out.println(result.getText());
}
public void onFailure(Throwable t) {
reportError(t);
}
}
executor);
// ...
Web
// ...
const ai = getAI(firebaseApp, { backend: new GoogleAIBackend() });
const model = getTemplateGenerativeModel(ai);
const templateID = getValue(remoteConfig, 'template_id').asString();
const customerName = 'Jane';
// When making the `generateContent` call, source the template ID value from Remote Config
const result = await model.generateContent(
templateID,
// Provide the values for any input variables required by your template
{
customerName: customerName,
}
);
// ...
Dart
// ...
final model = FirebaseAI.googleAI().templateGenerativeModel();
final templateID = remoteConfig.getString("template_id");
final customerName = 'Jane';
// When making the `generateContent` call, source the template ID value from Remote Config
var response = await model.generateContent(
templateID,
// Provide the values for any input variables required by your template
inputs: {
'customerName': customerName,
},
);
// ...
Unity
// ...
var ai = FirebaseAI.GetInstance(FirebaseAI.Backend.GoogleAI());
var templateID = remoteConfig.GetValue("template_id").StringValue;
var model = ai.GetTemplateGenerativeModel();
var customerName = "Jane";
try
{
// When making the `generateContent` call, source the template ID value from Remote Config
var response = await model.GenerateContentAsync(
templateID,
// Provide the values for any input variables required by your template
new Dictionary<string, object>
{
{ "customerName", customerName },
}
);
Debug.Log($"Response Text: {response.Text}");
}
catch (Exception e)
{
Debug.LogError($"An error occurred: {e.Message}");
}
// ...
Krok 7. Uruchom aplikację
Skompiluj i uruchom aplikację oraz sprawdź, czy działa. Wprowadź zmiany w swojej konfiguracji na stronie Remote Config w konsoli Firebase, opublikuj je i sprawdź wynik.
Dalsze kroki
Dowiedz się więcej o implementowaniu innych przypadków użycia dla Remote Config i Firebase AI Logic.
W przypadku aplikacji i gier mobilnych:
Testuj zmiany szablonu za pomocą Remote Config i A/B Testing.
Stopniowo wdrażaj zmiany za pomocą Remote Config wdrożeń (tylko na iOS+ i Androidzie).
Używaj Remote Config personalizacji aby wykorzystać uczenie maszynowe do określania najlepszych ustawień dla poszczególnych użytkowników (tylko na iOS+, Androidzie i Unity).