Skip to content

Most visited

Recently visited

navigation

네트워크 데이터 사용량 최적화

스마트폰의 수명 전체에 걸쳐, 모바일 데이터 요금제에 따른 비용이 기기 자체의 가격을 쉽게 초과할 수 있습니다. Android 7.0(API 레벨 24)부터는 사용자들이 기기 전체에서 데이터 세이버를 활성화하여 기기의 데이터 사용량을 최적화하고 줄일 수 있습니다. 이 기능은 로밍 중이거나, 결제 주기가 끝날 무렵이거나, 소액 선불 데이터 팩을 사용 중인 경우에 특히 유용합니다.

사용자가 Settings에서 데이터 세이버를 활성화하고 해당 기기가 데이터 통신 네트워크에 있는 경우, 시스템은 백그라운드 데이터 사용을 차단하고 가능하면 포그라운드에서 데이터를 더 적게 사용하도록 앱에게 신호를 보냅니다. 사용자는 데이터 세이버가 켜진 경우에도 백그라운드 데이터 통신 연결을 허용하기 위해 특정 앱을 허용 목록에 추가할 수 있습니다.

N Developer Preview는 ConnectivityManager API를 확장하여 사용자의 데이터 세이버 기본 설정을 검색하고 기본 설정 변경을 모니터링하는 방법을 앱에 제공합니다. 사용자가 데이터 세이버를 활성화했는지 여부를 앱이 확인하고 포그라운드 및 백그라운드 데이터 사용을 제한하기 위해 앱이 노력하는 것은 좋은 방법입니다.

데이터 세이버 기본 설정 확인

N Developer Preview에서 앱이 ConnectivityManager API를 사용하여, 어떤 데이터 사용량 제한이 적용되고 있는지를 확인할 수 있습니다. getRestrictBackgroundStatus() 메서드는 다음 값 중 하나를 반환합니다.

RESTRICT_BACKGROUND_STATUS_DISABLED
데이터 세이버가 비활성화되었습니다.
RESTRICT_BACKGROUND_STATUS_ENABLED
사용자가 이 앱에 대해 데이터 세이버를 활성화했습니다. 앱은 포그라운드에서 데이터 사용량을 제한하고, 백그라운드 데이터 사용량에 대한 제한을 적절히 처리하기 위해 노력해야 합니다.
RESTRICT_BACKGROUND_STATUS_WHITELISTED
사용자가 데이터 세이버를 활성화했지만 앱이 허용 목록에 추가되어 있습니다. 앱은 포그라운드 및 백그라운드 데이터 사용량을 제한하기 위해 여전히 노력해야 합니다.

데이터 세이버가 비활성화되어 있거나 앱이 허용 목록에 추가되어 있더라도, 기기가 데이터 통신 네트워크에 연결될 때마다 항상 데이터 사용량을 제한하는 것이 좋은 방법입니다. 다음 샘플 코드에서는 ConnectivityManager.isActiveNetworkMetered()ConnectivityManager.getRestrictBackgroundStatus()를 사용하여 앱이 사용해야 하는 데이터의 양을 결정합니다.

ConnectivityManager connMgr = (ConnectivityManager)
        getSystemService(Context.CONNECTIVITY_SERVICE);
// Checks if the device is on a metered network
if (connMgr.isActiveNetworkMetered()) {
  // Checks user’s Data Saver settings.
  switch (connMgr.getRestrictBackgroundStatus()) {
    case RESTRICT_BACKGROUND_STATUS_ENABLED:
    // Background data usage is blocked for this app. Wherever possible,
    // the app should also use less data in the foreground.

    case RESTRICT_BACKGROUND_STATUS_WHITELISTED:
    // The app is whitelisted. Wherever possible,
    // the app should use less data in the foreground and background.

    case RESTRICT_BACKGROUND_STATUS_DISABLED:
    // Data Saver is disabled. Since the device is connected to a
    // metered network, the app should use less data wherever possible.
  }
} else {
  // The device is not on a metered network.
  // Use data as required to perform syncs, downloads, and updates.
}

허용 목록 권한 요청

앱이 백그라운드에서 데이터를 사용해야 하는 경우, 앱의 패키지 이름의 URI가 포함된 Settings.ACTION_IGNORE_BACKGROUND_DATA_RESTRICTIONS_SETTINGS 인텐트(예: package:MY_APP_ID)를 앱이 보내서 허용 목록 권한을 요청할 수 있습니다.

인텐트와 URI를 보내면 Settings 앱이 시작되고 앱에 대한 데이터 사용량 설정이 표시됩니다. 그러면 사용자는 앱에 대해 백그라운드 데이터의 사용 여부를 결정할 수 있습니다. 이 인텐트를 보내기 전에, 백그라운드 데이터 사용을 활성화하기 위해 Settings 앱 시작 여부를 사용자에게 먼저 묻는 것이 좋습니다.

데이터 세이버 기본 설정 변경 사항 모니터링

앱은 ConnectivityManager.ACTION_RESTRICT_BACKGROUND_CHANGED를 수신하기 위해 BroadcastReceiver를 생성하고 수신기를 Context.registerReceiver()에 동적으로 등록하는 방식으로 데이터 세이버 기본 설정의 변경사항을 모니터링할 수 있습니다. 앱은 이 브로드캐스트를 수신할 때 ConnectivityManager.getRestrictBackgroundStatus()를 호출하여 새로운 데이터 세이버 기본 설정이 권한에 영향을 미치는지 확인해야 합니다.

참고: 시스템에서는 Context.registerReceiver()로 동적으로 등록하는 앱에만 이 브로드캐스트를 보냅니다. 이 브로드캐스트를 수신하도록 매니페스트에 등록하는 앱은 이를 수신하지 못합니다.

Android 디버그 브리지 명령어를 이용한 테스트

Android 디버그 브리지(ADB)는 데이터 세이버 상태에서 앱을 테스트하는 데 사용할 수 있는 몇 가지 명령어를 제공합니다. 네트워크 권한을 확인하고 구성하거나 무선 네트워크의 사용량을 측정하도록 설정하여 고정 요금제 네트워크에서 앱을 테스트할 수 있습니다.

$ adb shell dumpsys netpolicy
현재 전역 백그라운드 네트워크 제한 설정, 허용 목록에 현재 있는 패키지 UID 및 알려진 다른 패키지의 네트워크 권한이 포함된 보고서를 생성합니다.
$ adb shell cmd netpolicy
Network Policy Manager(netpolicy) 명령의 전체 목록을 표시합니다.
$ adb shell cmd netpolicy set restrict-background <boolean>
true 또는 false를 각각 전달할 때 데이터 세이버 모드를 활성화하거나 비활성화합니다.
$ adb shell cmd netpolicy add restrict-background-whitelist <UID>
지정된 패키지 UID를 허용 목록에 추가하여 백그라운드 데이터 통신 연결을 허용합니다.
$ adb shell cmd netpolicy remove restrict-background-whitelist <UID>
지정된 패키지 UID를 허용 목록에서 제거하여, 데이터 세이버가 활성화된 동안 백그라운드 데이터 통신 연결을 차단합니다.
$ adb shell cmd netpolicy list wifi-networks
모든 Wi-Fi 네트워크를 사용량 측정 여부와 함께 표시합니다.
$ adb shell cmd netpolicy set metered-network <WIFI_SSID> true
지정된 SSID를 가진 Wi-Fi의 사용량을 측정하도록 설정하기 때문에 고정 요금제 네트워크에서 측정 네트워크를 시뮬레이션할 수 있습니다.
This site uses cookies to store your preferences for site-specific language and display options.

Get the latest Android developer news and tips that will help you find success on Google Play.

* Required Fields

Hooray!

Follow Google Developers on WeChat

Browse this site in ?

You requested a page in , but your language preference for this site is .

Would you like to change your language preference and browse this site in ? If you want to change your language preference later, use the language menu at the bottom of each page.

This class requires API level or higher

This doc is hidden because your selected API level for the documentation is . You can change the documentation API level with the selector above the left navigation.

For more information about specifying the API level your app requires, read Supporting Different Platform Versions.

Take a short survey?
Help us improve the Android developer experience.
(Sep 2017 survey)