Excessive partial wake locks

Partial wake locks are a mechanism in the PowerManager API that lets developers keep the CPU running after a device's display turns off (whether due to system timeout or the user pressing the power button). Your app acquires a partial wake lock by calling acquire() with the PARTIAL_WAKE_LOCK flag, or by using other APIs that acquire wake locks. Excessive use of partial wake locks drains the device's battery because it prevents the device from entering lower power states. Partial wake locks should be used only when necessary and released as soon as no longer needed.

If your app uses partial wake locks excessively, you can use the guidance in this page to diagnose and fix the problem.

Your feedback is a crucial part of improving our documentation. Please give us your feedback using the following link:

Give feedback

Detect the problem

Android vitals can help you find out when your app's use of partial wake locks is excessive.

Android vitals

Android vitals can help improve your app's performance by alerting you via the Play Console when your app's use of partial wake locks is excessive.

Android vitals reports partial wake lock use as excessive when all of the partial wake locks, added together, run for 2 or more hours in a 24-hour period. Android vitals tracks wake lock duration only if the wake lock is held when the app is in the background or is running a foreground service. Currently, Android vitals exempts wake locks created by audio, location, and JobScheduler user-initiated APIs from the wake lock calculation.

The Android vitals excessive partial wake lock dashboard provides breakdowns of non-exempted wake lock names associated with your app, showing affected sessions and durations.

If excessive partial wake locks occur in more than 5% of app sessions across all devices in a 28-day period, it can affect your app's visibility on Play once the metric is out of beta.

Once you're aware that your app has excessive partial wake locks, your next step is to address the issue.

Fix the problem

Because wake locks can drain the device battery, you shouldn't use wake locks if there's an alternative. The Choose the right API to keep the device awake documentation can help you find the best solution for your app.

If you do need to use a wake lock, follow wake lock best practices to make sure your wake locks don't hurt device efficiency. In particular, make sure every device you acquire is released, and release the lock as quickly as possible.

Your app might also be using wake locks even if you aren't acquiring the wake lock explicitly. If you see wake locks attributed to the app that you don't recognize, identify wake locks created by other APIs can help you identify the APIs that might have created them.

After fixing the problem in code, you can verify your fixes by using local wake lock debugging tools.

See also