Firebase 원격 구성으로 클라우드에서 앱의 매개변수를 정의하고 값을 업데이트하면 앱 업데이트를 배포하지 않고도 앱의 모양과 동작을 수정할 수 있습니다. 이 가이드에서는 시작하는 단계를 안내하고 샘플 코드를 제공합니다.
1단계: 앱에 Firebase 및 원격 구성 SDK 추가
아직 수행하지 않았으면 Flutter의 Firebase SDK를 설치하고 초기화합니다.
원격 구성의 경우 사용자 속성 및 잠재고객에 대한 앱 인스턴스의 조건부 타겟팅에는 Google 애널리틱스가 필수입니다. 프로젝트에서 Google 애널리틱스를 사용 설정해야 합니다.
Flutter 프로젝트의 루트 디렉터리에서 다음 명령어를 실행하여 원격 구성 플러그인을 설치합니다.
flutter pub add firebase_remote_config
또한 원격 구성을 설정하는 과정에서 앱에 Google 애널리틱스용 Firebase SDK를 추가해야 합니다.
flutter pub add firebase_analytics
프로젝트를 다시 빌드합니다.
flutter run
macOS에서 원격 구성을 사용하는 경우 Xcode에서 키체인 공유를 사용 설정합니다.
2단계: 원격 구성 싱글톤 객체 가져오기
원격 구성 객체 인스턴스를 불러온 뒤 가져오기 간격을 최솟값으로 설정하여 상시적으로 새로고침을 할 수 있도록 합니다.
final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
fetchTimeout: const Duration(minutes: 1),
minimumFetchInterval: const Duration(hours: 1),
));
이 싱글톤 객체를 사용하여 인앱 매개변수 기본값을 저장하고 업데이트된 매개변수 값을 백엔드에서 가져오며 가져온 값을 앱에 제공할 시점을 제어합니다.
개발 중에는 가져오기 간격 최솟값을 상대적으로 낮게 설정하는 것이 좋습니다. 자세한 내용은 제한을 참조하세요.
3단계: 인앱 매개변수 기본값 설정
원격 구성 객체에 인앱 매개변수 기본값을 설정하면 앱이 원격 구성 백엔드에 연결되기 전에 의도한 대로 작동하고 백엔드에서 아무것도 설정하지 않으면 기본값이 사용됩니다.
await remoteConfig.setDefaults(const {
"example_param_1": 42,
"example_param_2": 3.14159,
"example_param_3": true,
"example_param_4": "Hello, world!",
});
4단계: 앱에서 사용할 매개변수 값 가져오기
이제 원격 구성 객체에서 매개변수 값을 가져올 수 있습니다. 백엔드에서 값을 설정한 후 값을 가져와서 활성화하면 이 값이 앱에 적용됩니다. 그렇지 않은 경우 setDefaults()
를 사용하여 인앱 매개변수 값을 구성합니다.
이러한 값을 가져오려면 매개변수 키를 인수로 전달하여 앱의 예상 데이터 유형에 매핑하는 아래의 메서드를 호출합니다.
getBool()
getDouble()
getInt()
getString()
5단계: 원격 구성 백엔드에 매개변수 값 설정
Firebase Console 또는 원격 구성 백엔드 API를 사용하여 원하는 조건부 로직 또는 사용자 타겟팅에 따라 인앱 값을 재정의하는 새 서버 측 기본값을 만들 수 있습니다. 이 섹션에서는 Firebase Console에서 이러한 값을 만드는 단계를 설명합니다.
- Firebase Console에서 프로젝트를 엽니다.
- 메뉴에서 원격 구성을 선택하여 원격 구성 대시보드를 표시합니다.
- 앱에 정의한 매개변수와 같은 이름으로 매개변수를 정의합니다. 각 매개변수에 기본값 및 조건부 값을 설정할 수 있습니다. 기본값은 이후에 해당하는 인앱 기본값을 재정의합니다. 자세한 내용은 원격 구성 매개변수 및 조건을 참조하세요.
6단계: 값 가져오기 및 활성화
원격 구성 백엔드에서 매개변수 값을 가져오려면
fetch()
메서드를 호출합니다. 백엔드에 설정한 모든 값을 가져와 원격 구성 객체에 저장합니다.가져온 매개변수 값을 앱에 적용하려면
activate()
메서드를 호출합니다.호출 한 번으로 값을 가져오고 활성화하려는 경우에는
fetchAndActivate()
요청으로 원격 구성 백엔드에서 값을 가져와 앱에서 사용할 수 있습니다.await remoteConfig.fetchAndActivate();
이러한 업데이트된 매개변수 값은 앱의 동작과 모양에 영향을 주므로 사용자 경험에 방해가 되지 않을 만한 시점, 예를 들어 사용자가 다음번에 앱을 열 때 등과 같은 상황에서 가져온 값을 활성화하는 것이 좋습니다. 자세한 내용과 예시는 원격 구성 로딩 전략을 참조하세요.
7단계: 실시간 업데이트 리슨
매개변수 값을 가져온 후 실시간 원격 구성을 사용하여 원격 구성 백엔드의 업데이트를 리슨할 수 있습니다. 실시간 원격 구성은 사용 가능한 업데이트가 있을 때 연결된 기기에 신호를 보내고 새로운 원격 구성 버전을 게시한 후 변경사항을 자동으로 가져옵니다.
웹에서는 실시간 원격 구성을 사용할 수 없습니다.
앱에서
onConfigUpdated
를 사용하여 업데이트 리슨을 시작하고 새 매개변수 값을 자동으로 가져옵니다.remoteConfig.onConfigUpdated.listen((event) async { await remoteConfig.activate(); // Use the new config values here. });
다음에 새로운 버전의 원격 구성을 게시하면 앱을 실행하고 변경사항을 리슨하는 기기가 새로운 구성을 활성화합니다.
제한
앱에서 단기간에 가져오기를 너무 많이 수행하면 가져오기 호출이 제한되고 FirebaseRemoteConfig
의 lastFetchStatus
속성 값은 RemoteConfigFetchStatus.throttle
이 됩니다.
원격 구성의 가져오기 간격 최솟값은 12시간(기본값)입니다. 즉, 실제로 발생하는 가져오기 호출 수에 관계없이 12시간 동안 백엔드에서 구성을 두 번 이상 가져올 수 없습니다.
앱 개발 단계에서는 실시간 원격 구성을 사용하지 않는 경우(권장) 앱을 개발하고 테스트할 때 빠르게 반복할 수 있도록 구성 가져오기와 활성화를 자주(한 시간에 몇 번씩) 해야 할 수도 있습니다. 개발자가 10명 이하인 프로젝트에서는 빠르게 반복할 수 있도록 setConfigSettings()
를 사용하여 가져오기 간격 최솟값을 임시로 낮게 설정할 수 있습니다.
final remoteConfig = FirebaseRemoteConfig.instance;
await remoteConfig.setConfigSettings(RemoteConfigSettings(
fetchTimeout: const Duration(minutes: 1),
minimumFetchInterval: const Duration(minutes: 5),
));
다음 단계
아직 살펴보지 않았다면 Remote Config에서 살펴보세요. 사용 사례를 살펴보고 주요 개념 및 고급 전략 문서: