يتغيّر مدى توفّر نماذج الذكاء الاصطناعي التوليدي بشكل متكرّر، إذ يتم إطلاق نماذج جديدة وأفضل، وإيقاف النماذج الأقدم والأقل كفاءة.
عند الوصول إلى نماذج الذكاء الاصطناعي التوليدي مباشرةً من تطبيق على الجهاز الجوّال أو تطبيق ويب باستخدام Firebase AI Logic، من الضروري ضبط تطبيقك لاستيعاب هذه التغييرات المتكررة في النماذج. لن يحدِّث جميع المستخدمين تطبيقك إلى أحدث إصدار لبدء استخدام النموذج الذي تريد منهم استخدامه.
تتيح لك ميزة Firebase Remote Config تعديل قيم المَعلمات في تطبيقك (مثل اسم نموذج) بشكل ديناميكي وعن بُعد من وحدة تحكّم Firebase، بدون الحاجة إلى طرح إصدار جديد من تطبيقك.
يُرجى العِلم أنّ تغيير اسم نموذج هو حالة استخدام مهمة لاستخدام Remote Config مع Firebase AI Logic، ولكن يمكنك أيضًا استخدام Remote Config للتحكّم بشكل ديناميكي وحتى مشروط في المَعلمات في تطبيقك، مثل إعدادات إنشاء النموذج (الحد الأقصى للرموز المميزة ودرجة الحرارة وما إلى ذلك)، وإعدادات الأمان وتعليمات النظام وبيانات الطلبات.
يوضّح هذا الدليل كيفية تنفيذ Remote Config في تطبيقك، وتحديدًا للتحكّم في اسم النموذج المستخدَم في تطبيقك.
الخطوة 1: ضبط قيمة المَعلمة في وحدة تحكّم Firebase
أنشئ نموذج Remote Config للعميل واضبط model_name
مَعلمة وقيمتها لاسترجاعها واستخدامها في التطبيق.
افتح مشروعك على Firebase في Firebase. بعد ذلك، من قائمة التنقّل، وسِّع تنفيذ (Run) وانقر على Remote Config.
تأكَّد من اختيار العميل من أداة اختيار العميل/الخادم في أعلى الصفحة.
ابدأ نموذج عميل بالنقر على إنشاء إعداد (أو إضافة مَعلمة إذا سبق لك استخدام نماذج العملاء).
حدِّد المَعلمة
model_name:اسم المَعلمة الوصف النوع القيمة التلقائية model_nameاسم الطراز يمكنك الاطّلاع على أسماء الطُرز المتاحة. سلسلة gemini-2.5-flashبعد إضافة هذه المَعلمة، انقر على نشر التغييرات. إذا لم يكن هذا Remote Config نموذجًا جديدًا، راجِع التغييرات وانقر على نشر التغييرات مرة أخرى.
الخطوة 2: إضافة Remote Config وتهيئة إعداداته في تطبيقك
أضِف مكتبة Remote Config واضبط إعداداتها في تطبيقك.Remote Config
Swift
كجزء من عملية Firebase AI Logic الإعداد، سبق لك إضافة حزمة تطوير البرامج (SDK) لمنصة Firebase إلى تطبيقك، ولكن عليك أيضًا إضافة Remote Config.
في Xcode، بعد فتح المشروع، انتقِل إلى ملف > إضافة موارد الاعتمادية للحزمة (File > Add Package Dependencies).
اختَر firebase-ios-sdk، ثم انقر على إضافة حزمة.
من "مستكشف المشروع" (Project navigator)، اختَر تطبيقك > الأهداف (Targets) > تطبيقك.
من علامة التبويب الإعدادات العامة، انتقِل إلى الأطر والمكتبات والمحتوى المضمّن.
انقر على + واختَر FirebaseRemoteConfig، ثم انقر على إضافة.
أضِف عملية استيراد
FirebaseRemoteConfigإلى الرمز:import FirebaseRemoteConfigداخل الفئة المناسبة لتطبيقك، عليك إعداد Firebase وإضافة Remote Config إلى منطق التطبيق الرئيسي.
في هذا القسم، ستدرِج Remote Config وRemote Config أداة الاستماع في الوقت الفعلي كعمليات استيراد حتى يتمكّن التطبيق من جلب القيم الجديدة في الوقت الفعلي، كما ستضيف الحد الأدنى لفاصل الجلب:
let remoteConfig = RemoteConfig.remoteConfig() let settings = RemoteConfigSettings() settings.minimumFetchInterval = 3600 remoteConfig.configSettings = settings
Kotlin
أضِف الاعتمادية Remote Config إلى ملف Gradle الخاص بالوحدة (على مستوى التطبيق) (عادةً
app/build.gradle.ktsأوapp/build.gradle):dependencies { implementation(platform("com.google.firebase:firebase-bom:34.5.0")) implementation("com.google.firebase:firebase-ai") implementation("com.google.firebase:firebase-config") // ... other dependencies }أضِف Remote Config إلى منطق تطبيقك الرئيسي. في هذا القسم، عليك ضبط قيمة Remote Config وإضافة الحدّ الأدنى لفاصل جلب البيانات:
val remoteConfig: FirebaseRemoteConfig = Firebase.remoteConfig val configSettings = remoteConfigSettings { minimumFetchIntervalInSeconds = 3600 } remoteConfig.setConfigSettingsAsync(configSettings)
Java
أضِف الاعتمادية Remote Config إلى ملف Gradle الخاص بالوحدة (على مستوى التطبيق) (عادةً
app/build.gradle.ktsأوapp/build.gradle):dependencies { implementation(platform("com.google.firebase:firebase-bom:34.5.0")) implementation("com.google.firebase:firebase-ai") implementation("com.google.firebase:firebase-config") // ... other dependencies }أضِف Remote Config إلى منطق تطبيقك الرئيسي. في هذا القسم، عليك ضبط قيمة Remote Config وإضافة الحدّ الأدنى لفاصل جلب البيانات:
FirebaseRemoteConfig mFirebaseRemoteConfig = FirebaseRemoteConfig.getInstance(); FirebaseRemoteConfigSettings configSettings = new FirebaseRemoteConfigSettings.Builder() .setMinimumFetchIntervalInSeconds(3600) .build(); mFirebaseRemoteConfig.setConfigSettingsAsync(configSettings);
Web
افتح الرمز في محرِّر نصوص واستورِد Remote Config:
import { getRemoteConfig } from 'firebase/remote-config';داخل وظيفتك الأساسية وبعد تهيئة تطبيق Firebase لحزمة تطوير البرامج (SDK) Firebase AI Logic، يمكنك تهيئة Remote Config:
// Initialize Remote Config and get a reference to the service const remoteConfig = getRemoteConfig(app);ضبط الحدّ الأدنى للفاصل الزمني بين عمليات الجلب:
remoteConfig.settings.minimumFetchIntervalMillis = 3600000;
Dart
من دليل مشروع Flutter، ثبِّت Remote Config وأضِف باستخدام الأمر التالي:
flutter pub add firebase_remote_configافتح
./lib/main.dartوأضِف عملية الاستيراد بعد عمليات الاستيراد الأخرى التي أضفتها لدعم 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';أضِف المتغيّر
_modelNameإلى تطبيقك لتتمكّن من استخدامه لاحقًا:late final String _modelName; late final String _systemInstructions; late final String _prompt;احصل على النسخة الافتراضية للعنصر Remote Config وحدِّد أقل فترة زمنية للاسترجاع من أجل السماح بإعادة التحميل بشكل متكرّر. احرِص على إضافة هذا الرمز بعد إعداد Firebase.
final remoteConfig = FirebaseRemoteConfig.instance; await remoteConfig.setConfigSettings(RemoteConfigSettings( fetchTimeout: const Duration(seconds: 3600), minimumFetchInterval: const Duration(seconds: 3600), ));
Unity
أضِف Remote Config إلى مشروع Unity باتّباع هذه التعليمات.
احصل على النسخة الافتراضية للعنصر Remote Config وحدِّد أقل فترة زمنية للاسترجاع من أجل السماح بإعادة التحميل بشكل متكرّر. احرِص على إضافة هذا الرمز بعد إعداد Firebase.
var remoteConfig = FirebaseRemoteConfig.DefaultInstance; const int MillisecondsPerSecond = 1000; await remoteConfig.SetConfigSettingsAsync(new ConfigSettings() { FetchTimeoutInMilliseconds = 3600 * MillisecondsPerSecond, MinimumFetchIntervalInMilliseconds = 3600 * MillisecondsPerSecond });
الخطوة 3: ضبط قيمة المَعلمة داخل التطبيق
عليك ضبط قيم المَعلمات التلقائية داخل التطبيق في العنصر Remote Config. يضمن ذلك أن يتصرف تطبيقك على النحو المتوقّع حتى إذا لم يتمكّن من جلب القيم من خدمة Remote Config.
Swift
في وحدة تحكّم Firebase، افتح Remote Config.
في علامة التبويب المَعلمات، افتح القائمة، ثم اختَر تنزيل القيم التلقائية.
عندما يُطلب منك ذلك، فعِّل ملف .plist لنظام التشغيل iOS، ثم انقر على تنزيل الملف.
احفظ الملف في دليل التطبيق.
في Xcode، انقر بزر الماوس الأيمن على تطبيقك واختَر إضافة ملفات
اختَر remote_config_defaults.plist، ثمّ انقر على إضافة.
عدِّل رمز تطبيقك للإشارة إلى ملف الإعدادات التلقائية:
// Set default values for Remote Config parameters. remoteConfig.setDefaults(fromPlist: "remote_config_defaults")
Kotlin
من وحدة تحكّم Firebase، افتح Remote Config.
في علامة التبويب المَعلمات، افتح القائمة، ثم اختَر تنزيل القيم التلقائية.
عندما يُطلب منك ذلك، فعِّل ملف .xml لنظام التشغيل Android، ثم انقر على تنزيل الملف.
احفظ الملف في دليل موارد XML الخاص بتطبيقك.
عدِّل ملف النشاط الرئيسي لإضافة القيم التلقائية بعد
configSettingsالتي أضفتها سابقًا:// Set default values for Remote Config parameters. remoteConfig.setDefaultsAsync(R.xml.remote_config_defaults)
Java
في وحدة تحكّم Firebase، افتح Remote Config.
في علامة التبويب المَعلمات، افتح القائمة، ثم اختَر تنزيل القيم التلقائية.
عندما يُطلب منك ذلك، فعِّل ملف .xml لنظام التشغيل Android، ثم انقر على تنزيل الملف.
احفظ الملف في دليل موارد XML الخاص بتطبيقك.
عدِّل ملف النشاط الرئيسي لإضافة القيم التلقائية بعد
configSettingsالتي أضفتها سابقًا:// Set default values for Remote Config parameters. mFirebaseRemoteConfig.setDefaultsAsync(R.xml.remote_config_defaults);
Web
يمكنك ضبط القيمة التلقائية لاسم النموذج مباشرةً في الرمز:
// Set default values for Remote Config parameters.
remoteConfig.defaultConfig = {
model_name: 'gemini-2.5-flash',
};
Dart
يمكنك ضبط القيمة التلقائية لاسم النموذج مباشرةً في الرمز:
// Set default values for Remote Config parameters.
remoteConfig.setDefaults(const {
"model_name": "gemini-2.5-flash"
});
Unity
يمكنك ضبط القيمة التلقائية لاسم النموذج مباشرةً في الرمز:
// Set default values for Remote Config parameters.
await remoteConfig.SetDefaultsAsync(
new System.Collections.Generic.Dictionary<string, object>() {
{ "model_name", "gemini-2.5-flash" }
}
);
الخطوة 4: استرجاع القيمة وتفعيلها
بعد ضبط القيمة التلقائية لاسم الطراز، أضِف ما يلي لجلب القيم وتفعيلها.
Swift
// Fetch and activate Remote Config values
remoteConfig.fetchAndActivate { status, error in
if let error = error {
print("Error fetching Remote Config: \(error.localizedDescription)")
}
}
يجب أن يؤدي ذلك إلى تعديل الكائن Remote Config كلما تم نشر نموذج Remote Config جديد.
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
أضِف
getValueوfetchAndActivateإلى عمليات الاستيراد:import { getValue, fetchAndActivate } from 'firebase/remote-config';ابحث عن الرمز الذي تحدّد فيه القيمة التلقائية لاسم الطراز. بعد كتلة الرموز هذه مباشرةً، أضِف الرمز التالي لجلب الإعداد وتفعيله وتعيين القيمة التي تم جلبها إلى الثابت
modelName.// 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 modelName = getValue(remoteConfig, 'model_name').asString();
Dart
// Fetch and activate Remote Config.
remoteConfig.fetchAndActivate();
// Assign Remote Config values.
String? _modelName = remoteConfig.getString("model_name");
Unity
// Fetch and activate Remote Config values.
await remoteConfig.FetchAndActivateAsync();
الخطوة 5: إضافة أداة معالجة Remote Config في الوقت الفعلي
أضِف برنامج معالجة Remote Config في الوقت الفعلي إلى تطبيقك لضمان نقل التغييرات التي تجريها على نموذج Remote Config إلى العميل فور تعديلها.
يعدّل الرمز التالي الكائن Remote Config كلما تغيّرت قيمة إحدى المَعلمات.
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
يمكنك أيضًا ضبط إجراء داخل عملية التفعيل 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
يمكنك أيضًا ضبط إجراء داخل عملية التفعيل 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
لا تتوافق أدوات معالجة Remote Config في الوقت الفعلي مع تطبيقات الويب.
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();
};
الخطوة 6: تعديل طلبات Gemini API لاستخدام قيمة Remote Config
|
انقر على موفّر Gemini API لعرض المحتوى والرمز الخاصين بموفّر الخدمة على هذه الصفحة. |
بعد إعداد Remote Config بالكامل، عدِّل الرمز البرمجي لاستبدال القيم المضمّنة بقيم مصدرها Remote Config.
Swift
import FirebaseAI
// When creating a `GenerativeModel` instance, source the model name value from Remote Config
let modelName = remoteConfig.configValue(forKey: "model_name").stringValue
let model = FirebaseAI.firebaseAI(backend: .googleAI()).generativeModel(
modelName: modelName
)
// ...
Kotlin
// When creating a `GenerativeModel` instance, source the model name value from Remote Config
val model = Firebase.ai(backend = GenerativeBackend.googleAI()).generativeModel(
modelName = remoteConfig.getString("model_name")
)
// ...
Java
// When creating a `GenerativeModel` instance, source the model name value from Remote Config
GenerativeModel ai = FirebaseAI.getInstance(GenerativeBackend.googleAI())
.generativeModel(
/* modelName */ remoteConfig.getString("model_name"),
/* generationConfig (optional) */ null,
/* safetySettings (optional) */ null,
/* requestOptions (optional) */ new RequestOptions(),
/* tools (optional) */ null,
/* toolsConfig (optional) */ null,
/* systemInstruction (optional) */ null,
);
GenerativeModelFutures model = GenerativeModelFutures.from(ai);
// ...
Web
// ...
const ai = getAI(firebaseApp, { backend: new GoogleAIBackend() });
// When creating a `GenerativeModel` instance, source the model name value from Remote Config
const model = getGenerativeModel(ai, {
model: modelName
});
// ...
Dart
// ...
// When creating a `GenerativeModel` instance, source the model name value from Remote Config
final model = FirebaseAI.googleAI().generativeModel(
model: _modelName,
);
// ...
Unity
// ...
var ai = FirebaseAI.GetInstance(FirebaseAI.Backend.GoogleAI());
// When creating a `GenerativeModel` instance, source the model name value from Remote Config
var modelName = remoteConfig.GetValue("model_name").StringValue;
var model = ai.GetGenerativeModel(
modelName: modelName
);
// ...
الخطوة 7: تشغيل التطبيق
أنشئ التطبيق وشغِّله وتأكَّد من أنّه يعمل. أجرِ تغييرات على إعداداتك من صفحة Remote Config في وحدة تحكّم Firebase، وانشر التغييرات، وتأكَّد من النتيجة.
الخطوات التالية
مزيد من المعلومات حول تنفيذ حالات استخدام أخرى لـ Remote Config وFirebase AI Logic
بالنسبة إلى تطبيقات وألعاب الأجهزة الجوّالة:
اختبِر إعدادات نماذج مختلفة باستخدام Remote Config وA/B Testing.
إصدار تغييرات مَعلمات النموذج تدريجيًا باستخدام عمليات طرح Remote Config (على أجهزة iOS وAndroid فقط)
استخدِم تخصيص Remote Config للاستفادة من تكنولوجيا تعلُّم الآلة في تحديد أفضل الإعدادات لكل مستخدم على حدة (على أجهزة iOS وAndroid وUnity فقط).