Users often invest significant time and effort creating an identity, adding data, and customizing settings and preferences within your app. Preserving this data and personalization for users when they upgrade to a new device or re-install your app is an important part of ensuring a great user experience. This page describes what data you should back up and the backup options available to you.
Select which data to back up
Users generate a lot of data when using your apps and you should take care to back up the appropriate data. Only backing up some of the data can frustrate users when they open the app on a new device and discover something missing. The important data to back up for your users is their identity data, user-generated app data, and settings data, as described below.
You can help maintain existing user engagement by transferring the user's account when they get started with a new device.
To begin, you should adopt Google Sign-In, which allows users to log-in automatically or with a single tap on their new device.
You can also integrate Smart Lock for Passwords, which instantly restores user sign-ins on a device. Smart Lock for Passwords supports saving both username-password credentials (for example, passwords) and federated identity provider credentials. The Autofill Framework also allows users to save passwords on devices running Android 8.0 and higher.
You can also use the Account Transfer API to copy over custom account credentials for your app from a user's existing device to a new device. The transfer takes place during setup of the new device over an encrypted bluetooth connection or device to device cable.
App data may include user-generated content, such as text, images, and other media. For restoring app data, see Transfer data using sync adapters or Google Drive Android API. You can use either approach to synchronize app data between Android-powered devices and save data which you'd like to use during the normal app lifecycle. You can also use either approach to restore a returning user's data onto a new device.
Make sure you also back up and restore settings data to preserve a returning user's personalized preferences on a new device. You can restore settings data even if a user doesn't log in to your app. You can back up settings that a user explicitly sets in your app's UI, as well as transparent data, such as a flag indicating whether a user has seen a setup wizard.
Note: Any permissions a user grants to your app are automatically backed up and restored by the system on devices running Android 7.0 (API 24) or newer. However, if a user uninstalls your app, then the system clears any granted permission and the user must grant them again.
To preserve as much of an existing user's experience on a new device as possible, make sure you back up the following user settings:
- Any settings modified by the user, for example using a
- Whether the user has turned notification and ringtones on or off.
- Boolean flags which indicate if the user has seen welcome screens or introductory tooltips.
One type of settings data you should avoid backing up is URIs because they can be unstable. In some cases a restoration to a new mobile device may result in an invalid URI that does not point to a valid file. One example of this is using URIs to save a user's ringtone preference. When the user reinstalls the app, the URI might point to no ringtone, or a different ringtone from the one intended. Instead of backing up the URI you can instead back up some metadata about the setting, such as a ringtone title or a hash of the ringtone.
Android provides two ways for apps to back up their data to the cloud: Auto backup for apps and Key/Value Backup. Auto Backup, which is available starting Android 6.0 (API level 23), preserves data by uploading it to the user's Google Drive account. Auto Backup includes files in most of the directories that are assigned to your app by the system. Auto Backup can store up to 25 MB of file-based data per app. The Key/Value Backup feature (formerly known as the Backup API and the Android Backup Service) preserves settings data in the form of key/value pairs by uploading it to the Android Backup Service.
Generally, we recommend Auto Backup because it's enabled by default and requires no work to implement. Apps that target Android 6.0 (API level 23) or higher are automatically enabled for Auto Backup. The Auto Backup feature is a file-based approach to backing up app data. While Auto Backup is simple to implement, you may consider using the Key/Value Backup feature if you have more specific needs for backing up data.
Note: If your app doesn't have a backup mechanism for app contents and the size of your app contents is unlikely to exceed the 25 MB limit, then Auto Backup may be sufficient for your needs.
The following table describes some of the key differences between Key/Value Backup and Auto Backup:
|Category||Key/Value Backup (Android Backup Service)||Android Auto Backup|
|Supported versions||Android 2.2 (API level 8) and higher.||Android 6.0 (API level 23) and higher.|
|Participation||Disabled by default. Apps can opt in by declaring a backup agent.||Enabled by default. Apps can opt out by disabling backups.|
Apps must implement a
||By default, Auto Backup includes almost all of the app's files. You can use XML to include and exclude files. Under the hood, Auto Backup relies on a backup agent that is bundled into the SDK.|
|Frequency||Apps must issue a request when there is data that is ready to be backed up. Requests from multiple apps are batched and executed every few hours.||Backups happen automatically roughly once a day.|
|Transmission||Backup data can be transmitted via Wi-Fi or cellular data.||Backup data is transmitted only via Wi-Fi. If the device is never connected to a Wi-Fi network, then Auto Backup never occurs.|
device conditions required for backup in
||Define device conditions required for backup in XML file (if using the default backup agent).|
|App shut down||Apps are not shut down during backup.||The system shuts down the app during backup.|
|User login||Doesn't require a user to be logged into your app. The user must be logged into the device with a Google account.||Doesn't require a user to be logged into your app. The user must be logged into the device with a Google account.|
|API||Related API methods are entity-based:||Related API methods are file-based:|
|Data restore||Data is restored when the app is installed. If needed, you can request a manual restore.||Data is restored when the app is installed. Users can select from a list of backup datasets if multiple datasets are available.|
|Documentation||Back Up key-value pairs with Android Backup Service||Back up user data with Auto Backup|
More information about how backup and restore works for each service is available in Test backup and restore.
Note: If Wi-Fi isn't available, Key/Value Backup may use mobile data. Key/Value Backup is therefore typically not suitable for app data contents, such as media, downloaded files, and caches, unless the amount of data is very small.