Android知识点 431 -- recovery 强制执行恢复出厂设置(Rescue Party)
转载原文:https://www.cnblogs.com/codeking100/p/10339258.html
返回知识列表:Android知识点list
1 Incremented rescue level to Factory Reset triggered by UID 100
第一句话实际上是进入的log典型信息
有时候我们在系统正常运行的时候,突然跑到recovery里面了,并且停在了如下界面:
意思是说,不能加载正常的安卓系统,可能数据损坏,如果你继续收到此消息,请执行恢复出厂设置擦除所有的用户数据。
我们查看下recovery的log:
cat /tmp/recovery.log
[ 1.516818] erasing_text: en (68 x 29 @ 990)
[ 1.520345] no_command_text: en (124 x 29 @ 990)
[ 1.523416] error_text: en (49 x 29 @ 990)
[ 1.993076] installing_text: en (228 x 29 @ 990)
[ 2.028634] SELinux: Loaded file_contexts
[ 2.028675] Command: "/sbin/recovery" "--prompt_and_wipe_data" "--reason=RescueParty" "--locale=en_US"
有参数“--prompt_and_wipe_data”,我们可以在google的官方查看此命令何意:
https://source.android.com/devices/tech/debug/rescue-party
这个需要代理服务器才能查看,我把原文贴下:
2 救援程序 RescueParty.java
很多用户严重依赖他们的手机,需要一台始终可以正常工作的设备。然而,有时设备会陷入重新启动循环僵局,这样,用户便需要提交支持服务单据或保修咨询。这个过程会让用户不舒服,而对于设备制造商和运营商来说,则需要支付高昂的费用。
Android 8.0 中纳入了一个功能,当该功能注意到核心系统组件(还包括常驻APP)陷入崩溃循环僵局时,就会派出“救援程序”。然后救援程序会通过一系列操作来上报相关情况,以期恢复设备。最后的解决方法是,救援程序使设备重新启动并进入恢复模式,然后提示用户恢复出厂设置。
因为,包括常驻APP的crash也会导致rescue,这就有些让人崩溃了,等于说应用的死影响到整个系统了,把整个系统拉入了recovery模式。(个人理解)
Android 兼容性定义文档并未要求提供此类救援功能,但此类功能对减少邮件支持记录来说非常有用。
3 实现
在 Android 8.0 中,救援程序默认处于启用状态,其实现位于/services/core/java/com/android/server/RescueParty.java 中。 在出现以下情况时,救援程序会收到有关启动和崩溃事件的信息,然后即会启动:
system_server 在 5 分钟内重启 5 次以上。
永久性系统应用在 30 秒内崩溃 5 次以上。
当检测到上述某种情况时,救援程序会将其上报给下一救援级别、处理与该级别相关联的任务,并让设备继续运行,看看能否恢复。清除或重置内容的程度随级别而增加。最高级别会提示用户将设备恢复出厂设置。
要支持救援程序,无需特别的硬件支持。实现后,设备的恢复系统必须响应 --prompt_and_wipe_data 命令,且设备必须先提供一种方法,让用户确认用户数据是否有任何损坏,然后再继续运行。此外,恢复系统还应为用户提供有关尝试再次启动设备的选项。
由于每个救援级别都会使设备再次变为可运行状态的时间延后(可能长达 5 分钟),因此设备制造商不应添加自定义救援级别。设备处于不可运行的状态的时间越长,用户发出支持请求或保修咨询,而不是自行恢复其设备的可能性就越大。
4 验证
当设备具有有效的 USB 数据连接时,系统会停止所有救援事件,因为这是一个较强的信号,表示有人正在调试设备。
(1)要停止此类抑制行为,请运行:
adb shell setprop persist.sys.enable_rescue 1
在此处,您可以触发系统或界面崩溃循环。
(2)要触发低级 system_server 崩溃循环,请运行:
adb shell setprop debug.crash_system 1
(3)要触发中级 SystemUI 崩溃循环,请运行:
adb shell setprop debug.crash_sysui 1
这两个崩溃循环都会启动救援逻辑。所有的救援操作也都会记录到存储在 /data/system/uiderrors.txt 中的永久性的 PackageManager 日志中,以供日后进行检查和调试。 此外,“软件包警告消息”部分下的每个错误报告中也会包含这些永久性的日志。
原来这个是android加的自动判断系统状态,实现的救援程序,触发进入recovery,强制执行恢复出厂设置。
有时候我们在断电煲机的时候,有时候会触发系统的救援程序,其实是在压力测试,但是触发了android本身的救援程序,我们可以把救援程序禁止,这样防止煲机触发进入recovery系统。
执行如下命令即可:setprop persist.sys.disable_rescue true
5 典型log输出
RescueParty: Attempting rescue level RESET_SETTINGS_UNTRUSTED_DEFAULTS
RescueParty: Noticed 2 events for UID 1000 in last 6 sec
RescueParty: Noticed 3 events for UID 1000 in last 9 sec
RescueParty: Noticed 4 events for UID 1000 in last 17 sec
RescueParty: Noticed 5 events for UID 1000 in last 29 sec
RescueParty: Attempting rescue level RESET_SETTINGS_UNTRUSTED_CHANGES
... 又死一遍
RescueParty: Attempting rescue level RESET_SETTINGS_TRUSTED_DEFAULTS
... 再死一遍
RescueParty: Attempting rescue level FACTORY_RESET 这就好去reboot了。进recovery , --reason=RescueParty
6 分析一下代码(未完成)
主要的代码路径:frameworks/base/services/core/java/com/android/server/RescueParty.java
Android知识点 431 -- recovery 强制执行恢复出厂设置(Rescue Party)相关推荐
- Android 8.1 recovery 强制执行恢复出厂设置
在工作中开发过程中,我们经常调试apk,然后推进机器里面去会已停止运行,你点几下就会恢复出厂设置. 意思是说,不能加载正常的安卓系统,可能数据损坏,如果你继续收到此消息,请执行恢复出厂设置擦除所有的用 ...
- recovery 强制执行恢复出厂设置(Rescue Party)
有时候我们在系统正常运行的时候,突然跑到recovery里面了,并且停在了如下界面: Can't load Android system. Your data may be corrupt. If y ...
- 强制执行恢复出厂设置android
前言 有时候我们在系统正常运行的时候,突然跑到recovery里面了,并且停在了如下界面 原因分析 我们查看下recovery的log: cat /tmp/recovery.log [ 1.51681 ...
- Android 9.0 进入recovery模式 自动恢复出厂设置的定制化
1.概述 在9.0 设备中,由于定制的设备没有音量+和音量-按键,所以通过手动选择recovery选择界面的模式时,就不能选择进入哪种模式,这时就需要进入recovery的时候,默认进入恢复出厂设置模 ...
- android平板怎么双清,华为M2平板10.0怎么双清?华为M2进入recovery格机恢复出厂设置...
双清对于搭载了安卓系统的华为M2平板电脑来说,是非常实用的一个功能,不管是刷固件出现系统问题,还是日常操作需要修复系统特殊异常情况都需要用到的操作.但是很多的华为M2平板用户并不了解这个操作怎么来进行 ...
- Android 如何才能捕获系统的恢复出厂设置事件
点击恢复出厂设置后,系统重启,再次进入系统后,一切数据都被清空,怎样可以得知之前到底是否恢复出厂设置了呢?怎样可以标记 恢复出厂设置事件 ?我希望在系统重启后,根据客户需求,判断出刚刚恢复过出厂设置, ...
- Android L集成新特性之恢复出厂设置保护之如何实现,类似苹果ID的远程控制功能
在Android 5.0 以后以后的设备默认开启恢复出厂设置保护功能,主要是为了减少用户在丢失手机的带来的损失,比如手机上的一些照片和其他一些重要资料被偷盗者非法利用.此功能可以让用户可以通过谷歌账号 ...
- android 设备管理器 解锁,4种方法解锁Android手机模式锁定而无需恢复出厂设置
第1部分:如何使用dr.fone解锁Android模式锁定而无需恢复出厂设置? 如果您正在寻找一种快速可靠的方式来移动任何Android设备上的锁定屏幕,那么只需尝试dr.fone - Android ...
- 魅蓝s6启动android密码_魅蓝s6怎么恢复出厂设置?忘记密码怎么办
魅蓝s6怎么恢复出厂设置?忘记密码怎么办?手机是现代生活必不可少的工具之一,在使用时我们常常会忘记手机密码.本次就给大家介绍手机密码忘了怎么恢复出厂设置,快来看看吧. 我们知道手机恢复出厂设置的注意事 ...
最新文章
- 2022-2028年中国复合软管行业市场行情动态及发展趋向分析报告
- 技术05期:五分钟教你读懂卷积神经网络【CNN】
- IntelliJ IDEA 、 Android Stadio 不显示Version Contro窗口
- 比特币经历价格过山车 理财还是乐金所、ppmoney网贷靠谱
- Mysql-高性能索引
- (三)、Express 路由、静态文件、
- [PAT乙级]1029 旧键盘
- Laravel 不同环境加载不同的.env文件
- Win7系统打开网页特别慢的解决方法
- 第十一节课 课堂总结
- T60 改LED 高压板连线方式。
- Oracle DBHelper
- 信号完整性分析学习--16--传输线效应
- jsp调用getParameterValues获取表单信息
- 牛腩--SQLHelper
- 计算机网络 latency,网络中delay和latency的区别
- matlab_plot实时画点
- Jungle Roads丛林道路(最小生成树PrimKruskal算法)
- Ubuntu系统优化工具stacer(推荐)
- 线性霍尔在汽车油门踏板上的应用
热门文章
- ​​​windows上传ipa到开发者中心(app store)的方法​​
- java的平均年龄怎么算,C#接收5个年龄和计算平均年龄
- debian常用命令整理
- CDA1级习题复习(3)
- signature=689995ceebd2e64b214c3148d7b8e47a,WDR34基因突变致窒息性胸廓发育不良1例报道并文献复习...
- 摄影几何基础知识(1)
- 织梦DedeCms网站信息统计代码
- 【Unity2D入门教程】简单制作一个弹珠游戏之制作场景③(设置砖块,添加碰撞)
- SPM 超级位置模型
- php bloomfilter,【Bloom filter】Python实现Bloom filter