手机电量消耗分析工具 Battery Historian 指南

news/2024/12/23 5:12:01/
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android

本篇文章主要介绍 Android 开发中 电量 的部分知识点,通过阅读本篇文章,您将收获以下内容:

一、安装Battery Historian
二、收集Batterystats 数据
三、使用Battery Historian分析数据
四、Batterystats 额外数据
五、使用Battery Historian 分析电量消耗
六、Battery Historian能干什么

本文主要分析了Batterystats工具和Battery Historian脚本的基本用法和工作流程。

Batterystats是一个包含在Android框架中的工具,用于收集设备上的电池数据。您可以使用adb将收集的电池数据转储到您的开发机器上,并创建一个报告,您可以使用Battery Historian进行分析。Battery Historian将来自Batterystats的报告转换为可在浏览器中查看的HTML可视化文件。

它有什么好处:

向您显示过程在何处以及如何从电池中吸取电流。
识别您的应用程序中可延期或甚至删除的任务以延长电池寿命。

一、安装Battery Historian

安装Battery Historian的最简单方法是使用Docker。有关备用安装方法(包括从源代码构建)。要使用Docker进行安装,请执行以下操作:

  • 1.按照Docker网站上的说明安装Docker Community Edition。

  • 2.要确认Docker已正确安装,请打开命令行并输入以下命令:
    docker run hello-world

ba476fe8718be5770fce7923cd971973.jpeg

Docker 成功安装信息

  • 3.使用以下命令运行Battery Historian图像:

docker --run -p port_number:9999 gcr.io/android-battery-historian:2.1 --port 9999

  • 4.在浏览器中导航到Battery Historian以确认它正在运行。地址因操作系统而异:

Linux and Mac
http://localhost/port_number
For Windows
http://123.456.78.90:port_number
您将看到Battery Historian起始页面,您可以在其中上载和查看电池统计信息。

2ca63cf1961c14108ee52a6af2d5f6af.jpeg

Battery Historian 首页

二、收集Batterystats 数据

连接手机,打开开发者模式,连接adb。

  • 1.重置 batterystats 数据

adb shell dumpsys batterystats --reset

设备始终在后台收集batterystats和其他调试信息。重置会清除旧电池采集数据.

  • 2.断开设备与电脑的连接,以便只从设备的电池中消耗电流。

  • 3.玩你的应用程序,并执行你想要的数据的行为; 例如,断开与WiFi的连接并将数据发送到云端。

  • 4.重新连接手机dump数据

adb shell dumpsys batterystats > [path/]batterystats.txt

  • 5.导出原始bugreport数据

Android 7.0 以上
adb bugreport > [path/]bugreport.zip

Android 5.0/ 6.0
adb bugreport > [path/]bugreport.txt

  • 6.打开并提交分析数据
    Battery Historian分析网站 需翻墙

三、使用Battery Historian分析数据

成功提交后,数据分析如下

eee9c1e6eb8b89c488894539c46114ea.jpeg

Battery Historian

  • 1.从下拉列表中添加其他指标。

  • 2.将鼠标悬停在信息图标上可查看有关每个指标的更多信息,包括图表中使用的颜色的关键字。

  • 3.将鼠标悬停在栏上,即可查看有关该指标的详细信息以及时间线上特定点的电池状态。

四、Batterystats 额外数据

Battery Historian图表下面的stats部分可以查看batterystats.txt文件中的其他信息。

40f05b6ec8bf7880c45dd1c57229d96e.jpeg

Batterystats 额外数据

  1. System Stats选项卡包含系统范围的统计信息,如单元信号级别和屏幕亮度。这些信息提供了设备发生情况的整体情况。这对确保没有外部事件影响您的测试特别有用。

  2. App Stats选项卡包含有关特定应用程序的信息。使用左侧的应用程序选择窗格中(图3)排序应用程序下拉列表对应用程序列表进行排序。您可以选择一个特定的应用程序来查看使用下面(图4)个应用程序下拉列表的统计信息。

五、使用 Battery Historian 分析电量消耗

Battery Historian工具提供了一段时间内设备电池消耗的深入分析。在全系统级别,该工具以HTML表示形式从系统日志中查看与电源相关的事件。在特定应用程序级别,该工具提供了各种数据,可帮助您确定电池耗尽应用程序的行为。

本文档介绍了使用Battery Historian了解电池消耗模式的一些方法。该文件首先解释如何读取Battery Historian报告的系统范围数据。然后,介绍如何使用Battery Historian诊断和解决与电池消耗有关的应用行为。最后,它提供了有关Battery Historian可能特别有用的场景的几个提示。

Battery Historian工具提供了各种应用程序和系统行为的系统范围可视化,以及随着时间的推移与电池消耗的相关性

5b9ac92398523e042ff591c3bc916a2d.jpeg

Battery Historian 事例

此图特别感兴趣的是在y轴上测量的代表电池电量的黑色水平下降趋势线。例如,在电池水平线的最开始时间点,大约早上6点50分,可视化显示电池电量水平相对急剧下降。

324275b0e978b50bc61d07834860e219.jpeg

CPU 唤醒锁等信息

在电池电量线开始时,随着电池电量急剧下降,显示屏显示出三件事:CPU正在运行,应用程序已获取唤醒锁,屏幕亮起。通过这种方式,Battery Historian可帮助您了解电池消耗高时发生的事件。然后,您可以将这些行为定位到您的应用中,并调查是否可以进行相关的优化。

除了系统范围内提供的宏观数据外,Battery Historian还提供特定于设备上运行的每个应用程序的表格和一些可视化数据。表格数据包括:

  • 该应用在设备上的预计用电量。

  • 网络信息。

  • Wakelocks。

  • 服务。

  • 进程信息。

这些表格提供了有关您的应用的两个维度数据。首先,您可以查看您的应用的用电量排名与其他应用的相比。为此,请单击表下的设备功率估算表。这个例子考察了一个名为Pug Power的虚构应用程序。

6bc02c0bcb68886772a2e5d3c33ff4be.jpeg

调查哪些应用程序消耗的功率最大

上图的表格显示,Pug Power是该设备上第九大电池供电用户,也是不属于操作系统的第三大应用。这个数据表明,这个应用程序承担更深入的调查。

要查找特定应用程序的数据,请将其包名称输入位于可视化左侧下方应用程序选择下的两个下拉菜单中的较低位置

4d0c7e6e693331059c358fb3fb70d731.jpeg

当您选择特定的应用程序时,以下数据可视化类别将更改为显示应用程序特定的数据而不是系统范围的数据:

  • SyncManager.

  • Foreground process.

  • Userspace Wakelock.

  • Top app.

  • JobScheduler.

  • Activity Manager Proc.

如果您的应用程序执行同步并执行作业的次数超过必要,SyncManager和JobScheduler可视化立即显而易见。在此过程中,他们可以快速发现优化应用行为以改善电池性能的机会。

您还可以获得更多的特定于应用程序的可视化数据,用户空间Wakelock。要将此信息包含在错误报告中,请在终端窗口中输入以下命令:
adb shell dumpsys batterystats --enable full-wake-history

ps:从Android 6.0(API级别23)开始,该平台包含Doze功能,这对应用程序实施了某些优化。例如,无论JobScheduler如何安排他们,Doze都会在短期维护时段内批处理作业。

ec4daf88cb8e1429b2da0e3c8f61b708.jpeg

显示特定应用的可视化数据

7dbe7e989d1501c48150b42dea87e5e1.jpeg

应用数据表格

看看可视化并不立即显示任何东西。JobScheduler行显示该应用程序没有计划任务。SyncManager行显示应用程序未执行任何同步。

然而,对表格数据的Wakelocks部分的检查表明,帕格电力总共花费了一个多小时的时间。这种不寻常的和昂贵的行为可以解释应用程序的高功耗水平。这一信息有助于开发人员瞄准优化可能极大帮助的领域。在这种情况下,为什么应用程序会获得如此多的唤醒时间,开发人员如何改善这种行为?

六、Battery Historian能干什么

Battery Historian还可以帮助您诊断改善电池行为的机会。例如,Battery Historian可以告诉你你的应用程序是否:

  • 过度频繁地发出唤醒警报(每10秒钟或更少)。

  • 持续持有GPS锁。

  • 每30秒或更短时间安排一次作业。

  • 计划每30秒或更短时间同步一次。

  • 更频繁地使用蜂窝无线电比您期望的更频繁。

至此,本篇已结束,如有不对的地方,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!

16ba1407dc3714e3076b7f675b5bb954.jpeg

点个在看,方便您使用时快速查找!


http://www.ppmy.cn/news/1509896.html

相关文章

Ubuntu 批量杀死进程

ps -ef|grep python|grep server|grep -v grep|cut -c 9-16|xargs kill -9这个命令序列是一个在Linux或类Unix系统中使用的脚本片段,用于批量终止(强制杀死)所有与特定条件(这里是包含"python"和"wanghao"的&…

鸿蒙(API 12 Beta3版)【Camera Kit简介】相机服务

开发者通过调用Camera Kit(相机服务)提供的接口可以开发相机应用,应用通过访问和操作相机硬件,实现基础操作,如预览、拍照和录像;还可以通过接口组合完成更多操作,如控制闪光灯和曝光时间、对焦或调焦等。 开发场景 …

场外期权交易:找到适合你的那一款

各位期权爱好者们!今天咱们来聊聊在进行场外期权交易时,怎么去评估和选择适合自己风险承受能力的期权产品。 第一,你得对自己有个清楚的认识。想想看,你是那种激进型的冒险家,还是保守型的稳健派呢?了解自己…

内部排序(插入、交换、选择)

一、排序的部分基本概念 1. 算法的稳定性 若待排序表中有两个元素 Ri 和 Rj ,其对应的关键字相同即 keyi keyj,且在排序前 Ri 在 Rj 的前面,若使用某一排序算法排序后,Ri 仍然在 Rj 的前面,则称这个排序算法是稳定的…

海山数据库(He3DB)源码解读:He3DB-XLogInsert函数

XLogInsert 函数主体参数 XLogRecPtr XLogInsert(RmgrId rmid, uint8 info) { }RmgrId rmid uint8类型的别名参数。唯一标识触发WAL记录生成的不同资源管理器 (Resource Manager ID) uint8 info 资源管理器其他额外信息 函数主题流程 XLogRecPtr XLo…

获取当前ip的网站--记录

https://www.ipuu.net/Homehttps://jingjiequ.com/tools/iphttps://www.ip.cn/https://api.bigdatacloud.net/data/client-ip [个人使用]http://myip.ipip.net/ 使用python获取当前ip代码案例 def get_ip():headers {"Accept": "text/html,application/xhtml…

Linux学习第60天:Linux驱动开发的一些总结

今天是Linux驱动开发的最后一个章节,题目中标明是60天完成的,其实在实际学习及笔记的整理中不止是60天。中间有过断更,有时断更的时间还是挺长的。这是在整个Linux驱动开发学习中最不满意的地方。 题目为Linux学习,其实这个题目有…

c++多态(二)

一、抽象类 在虚函数后面加 0 , 这个虚函数就是纯虚函数。(此函数只声明不实现) 有纯虚函数的类是抽象类。(无法实例化对象) 上图Car是一个抽象类,他的子类由于继承了纯虚函数,如果在子类重写纯虚函数也会…