콘솔로 이동

iOS에서 Firebase 원격 구성 시작하기

Firebase 원격 구성으로 클라우드에서 앱의 매개변수를 정의하고 값을 업데이트하면 앱 업데이트를 배포하지 않고도 앱의 모양과 동작을 수정할 수 있습니다.

이 가이드는 시작하는 단계를 안내하고 샘플 코드를 제공합니다. 이 샘플 코드는 firebase/quickstart-ios GitHub 저장소에서 클론하거나 다운로드할 수 있습니다.

앱에 원격 구성 추가

  1. iOS용 Firebase SDK를 설치합니다.

  2. 다음 예시와 같이 싱글톤 원격 구성 객체를 만듭니다.

    Swift

    Objective-C

이 객체를 사용하여 인앱 매개변수 기본값을 저장하고, 업데이트된 매개변수 값을 서비스에서 가져오고, 가져온 값을 앱에 제공할 시점을 제어합니다.

개발 중에는 가져오기 간격 최솟값을 상대적으로 낮게 설정하는 것이 좋습니다. 자세한 내용은 제한을 참조하세요.

인앱 매개변수 기본값 설정

원격 구성 객체에 인앱 매개변수 기본값을 설정하면 앱이 원격 구성 서비스에 연결되기 전이나 서비스에 설정된 매개변수 기본값이 없을 때의 앱 동작을 의도하는 대로 설정할 수 있습니다.

  1. NSDictionary 객체 또는 plist 파일을 사용하여 매개변수 이름과 기본 매개변수 값 집합을 정의합니다.
  2. setDefaults:를 사용하여 이러한 값을 원격 구성 객체에 추가합니다. 다음 예시는 plist 파일에서 인앱 기본값을 설정합니다.

Swift

Objective-C

앱에서 사용할 매개변수 값 가져오기

이제 원격 구성 객체에서 매개변수 값을 가져올 수 있습니다. 나중에 원격 구성 서비스에 값을 설정한 후 값을 가져와서 활성화하면 이 값이 앱에 적용됩니다. 그렇지 않으면 setDefaults:를 사용하여 구성한 인앱 매개변수 값을 가져옵니다. 이러한 값을 가져오려면 매개변수 키를 인수로 제공하여 configValueForKey: 메서드를 호출합니다.

서비스에서 매개변수 값 설정

Firebase Console 또는 Remote Config REST API를 사용하여 원하는 조건부 로직 또는 사용자 타겟팅에 따라 인앱 값을 재정의하는 새 서비스 측 기본값을 만들 수 있습니다. 이 섹션에서는 Firebase Console에서 이러한 값을 만드는 단계를 설명합니다.

  1. Firebase Console에서 프로젝트를 엽니다.
  2. 메뉴에서 원격 구성을 선택하여 원격 구성 대시보드를 표시합니다.
  3. 앱에 정의한 매개변수와 같은 이름으로 매개변수를 정의합니다. 각 매개변수에 기본값 및 조건부 값을 설정할 수 있습니다(기본값은 이후에 인앱 기본값을 재정의함). 자세한 내용은 원격 구성 매개변수 및 조건을 참조하세요.

서비스에서 값을 가져와서 활성화

  1. 원격 구성 서비스에서 매개변수 값을 가져오려면 fetchWithCompletionHandler: 또는 fetchWithExpirationDuration:completionHandler: 메서드를 호출합니다. 원격 구성 서비스에 설정한 모든 값이 수신되어 원격 구성 객체에 캐시됩니다.
  2. 가져온 매개변수 값을 앱에 적용하려면 activateFetched 메서드를 호출합니다.

호출 한 번으로 값을 가져오고 활성화하려면 fetchAndActivateWithCompletionHandler:를 사용합니다.

이 예시에서는 캐시된 값이 아니라 원격 구성 서비스에서 값을 가져오고 activateWithCompletionHandler:를 호출하여 해당 값을 앱에 적용합니다.

Swift

Objective-C

이러한 업데이트된 매개변수 값은 앱의 동작과 모양에 영향을 주므로 사용자 경험에 방해가 되지 않을 만한 시점, 예를 들어 사용자가 다음 번에 앱을 열 때 등과 같은 상황에서 가져온 값을 활성화하는 것이 좋습니다. 자세한 내용과 예시는 원격 구성 로딩 전략을 참조하세요.

제한

앱에서 단기간에 가져오기를 너무 많이 수행하면 가져오기 호출이 제한되고 SDK는 FIRRemoteConfigFetchStatusThrottled를 반환합니다. SDK 버전 6.3.0 이전에는 60분 동안 가져오기 요청 수가 5회로 제한되었지만 최신 버전에서는 좀 더 많이 허용합니다.

앱을 개발하는 동안 캐시를 자주(한 시간에 몇 번씩) 새로고치면 앱을 개발하고 테스트할 때 빠르게 반복할 수 있습니다. 개발자가 많은 프로젝트에서는 개발과 테스트를 빠르게 반복할 수 있도록 앱에서 FIRRemoteConfigSettings 속성을 가져오기 간격 최솟값(MinimumFetchInterval)으로 임시로 추가할 수 있습니다.

원격 구성의 권장되는 기본 프로덕션 가져오기 간격은 12시간(기본값)입니다. 즉, 실제로 발생하는 가져오기 호출 수에 관계없이 12시간 동안 백엔드에서 구성을 두 번 이상 가져올 수 없습니다. 가져오기 간격 최솟값은 구체적으로 다음과 같은 순서로 결정됩니다.

  1. fetch(long)의 매개변수
  2. FIRRemoteConfigSettings.MinimumFetchInterval의 매개변수
  3. 기본값 12시간

다음 단계

아직 원격 구성 사용 사례를 살펴보지 않았다면 살펴보고 다음을 포함하여 주요 개념과 고급 전략 문서를 참조하세요.