前台服务超时

如果应用以 Android 15 或更高版本为目标平台,系统会限制某些前台服务在应用处于后台状态时允许运行的时间。目前,此限制仅适用于 dataSyncmediaProcessing 前台服务类型的前台服务。shortService 前台服务类型的限制更为严格,相关内容将在该服务类型的文档中进行讨论。

超时行为

系统允许 dataSyncmediaProcessing 前台服务在 24 小时内总共运行 6 小时,之后系统会调用正在运行的服务的 Service.onTimeout(int, int) 方法(在 Android 15 中引入)。(mediaProcessing 前台服务类型是在 Android 15 中添加的。)dataSyncmediaProcessing 服务的 6 小时时限是分开跟踪的。例如,如果 dataSync 服务刚刚运行了一小时,则应用只有 5 小时可用于 dataSync 前台服务,但有整整 6 小时可用于 mediaProcessing 服务。

当前台服务达到 6 小时限制时,该服务有几秒钟的时间来调用 Service.stopSelf()。当系统调用 Service.onTimeout() 时,该服务不再被视为前台服务。如果服务未调用 Service.stopSelf(),系统会抛出内部异常。系统会在 Logcat 中记录以下消息:

Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type [service type] did not stop within its timeout: [component name]"

为避免此行为变更带来的问题,您可以执行以下一项或多项操作:

  1. 让您的服务实现新的 Service.onTimeout(int, int) 方法。当应用收到回调时,请务必在几秒钟内调用 stopSelf()。(如果您未立即停止应用,系统会生成失败消息。)
  2. 请确保您的应用的 dataSyncmediaProcessing 服务在任何 24 小时的时间段内总共运行时间不超过 6 小时(除非用户与应用互动,从而重置计时器)。
  3. 仅在用户直接互动时启动 dataSyncmediaProcessing 前台服务;由于应用在服务启动时位于前台,因此服务在应用进入后台后有整整 6 小时的运行时间。
  4. 请使用 替代 API(例如 WorkManager),而不是使用这些前台服务。特别是,请考虑使用替代 API,而不是使用 dataSync 前台服务。

如果您的应用的 dataSync 前台服务在过去 24 小时内已运行 6 小时,则您无法启动另一项 dataSync 前台服务,除非用户已将您的应用置于前台(这会重置计时器)。如果您尝试启动另一个 dataSync 前台服务,系统会抛出 ForegroundServiceStartNotAllowedException,并显示类似“Time limit already exhausted for foreground service type dataSync”(dataSync 类型的前台服务的时间限制已用尽)的错误消息。

测试

如需测试应用的行为,即使应用未以 Android 15 为目标平台,您也可以启用数据同步超时(只要应用在 Android 15 设备上运行)。如需启用超时,请运行以下 adb 命令:

adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name

您还可以调整超时时间段,以便更轻松地测试应用在达到限制时的行为。如需为 dataSync 前台服务设置新的超时时间段,请运行以下 adb 命令:

adb shell device_config put activity_manager data_sync_fgs_timeout_duration duration-in-milliseconds

如需为 mediaProcessing 前台服务设置新的超时时间段,请运行以下命令:

adb shell device_config put activity_manager media_processing_fgs_timeout_duration duration-in-milliseconds