btrace

btrace

高效Android应用性能分析工具

btrace是一款开源的Android应用性能分析工具。它支持Windows平台,采用Java脚本语言,无需Python环境。通过优化数据处理,btrace大幅降低了内存占用和性能损耗。新增的渲染、Binder和线程创建等监控功能,为开发者提供全面的性能分析。btrace集成简单,配置灵活,是Android应用性能优化的有力工具。

btrace性能监控Android开发性能优化跟踪工具Github开源项目

btrace

英文版README

重大更新

  1. 用户体验: 我们现在支持Windows!不再依赖Python 2.7和存储权限!脚本语言已更改为Java,将脚本工具的可用性问题造成的中断几乎降至零!我们还切换到PB协议来处理跟踪文件,使存储需求减少70%,打开跟踪文件的速度提升7倍。
  2. 性能体验: 重写了方法跟踪收集逻辑,将数据从字符串转换为整数,内存使用减少80%。数据存储改为mmap模式,优化了无锁队列逻辑,提供了精确的插桩策略,在数百万方法插桩的情况下,进一步将性能损失降低到15%!
  3. 监控数据: 新增4种数据监控能力,包括渲染、Binder、线程创建以及Wait/Notify/Park/Unpark的详细数据!

集成

项目配置

在项目根目录的build.gradle文件中添加rhea-gradle-plugin作为依赖:

buildscript { dependencies { classpath 'com.bytedance.btrace:rhea-gradle-plugin:2.0.3-rc02' } }

然后,在app/build.gradle文件中应用以下插件和依赖。

dependencies { // rheatrace核心库 implementation "com.bytedance.btrace:rhea-core:2.0.3-rc02" } ... apply plugin: 'com.bytedance.rhea-trace' ... rheaTrace { compilation { traceFilterFilePath = "${project.rootDir}/trace-filter/traceFilter.txt" needPackageWithMethodMap = true applyMethodMappingFilePath = "" } }

插件配置

RheaTrace 2.0简化了编译插件配置,只需要一个编译配置来控制编译期间的行为。RheaTrace 1.0中的运行时配置已被弃用,但为了确保升级时的兼容性,我们仍然保留了运行时参数配置,尽管它不会影响行为。相反,在RheaTrace 2.0中,动态配置是通过脚本中的命令行参数实现的,这将在后面详细描述。

参数默认值描述
traceFilterFilePathnull此文件决定哪些方法需要被插桩,其用法与RheaTrace 1.0一致。请参考:RheaTrace Gradle插件配置
applyMethodMappingFilePathnull可以通过指定上一次编译输出的methodMapping.txt文件路径来指定设备的方法ID,以确保多次编译的方法ID一致。
needPackageWithMethodMaptrue是否将methodMapping.txt文件打包到apk内。

使用方法

要使用RheaTrace 2.0,请按以下步骤操作:

  1. 确保你的电脑已集成adb和Java环境。
  2. 将手机连接到电脑,并确保adb devices能识别到。
  3. 在手机上安装集成了RheaTrace 2.0的APK。
  4. 从下方的"脚本管理"下载最新脚本到电脑。
  5. 在电脑脚本所在目录执行以下命令。
java -jar rhea-trace-shell.jar -a ${你的应用包名} -t 10 -o output.pb -r rhea.all sched -fullClassName
  1. 可以通过 https://ui.perfetto.dev/ 分析跟踪文件。

脚本管理

版本发布日期下载发布说明
2.0.02023-06-24rhea-trace-shell-2.0.0.jar2.0.0 首次发布

参数说明

下表描述了 RheaTrace 2.0 命令行参数:

必需参数

参数默认值描述
-a $applicationName不适用指定您的应用程序包名

可选参数

参数默认值描述
-o $outputPath不适用指定保存跟踪文件的路径。默认值根据时间戳自动生成。
-t $timeInSecond5指定跟踪时间长度,单位为秒。
-mode $mode根据设备指定跟踪模式。目前支持两种模式:1. perfetto:8.1及以上系统的默认模式,允许收集应用程序函数以及系统atrace和ftrace的跟踪。2. simple:8.1以下系统的默认模式,允许收集应用程序函数以及系统atrace的跟踪。
-maxAppTraceBufferSize $size500000000指定跟踪收集期间使用的缓冲区大小,单位为字节。通常不需要配置此参数,除非遇到类似以下提示:MaxAppTraceBufferSize太小。预期100515704 实际100000000。请在命令中添加-maxAppTraceBufferSize 100515704注意:maxAppTraceBufferSize仅在应用程序启动后的第一次跟踪中生效。
-threshold $ns0指定跟踪收集期间的函数时间阈值,单位为纳秒。此参数可在跟踪时间较长时减小跟踪文件的大小。
-s $serial指定通过adb连接的设备。
-mainThreadOnly不适用仅跟踪主线程。
-r自动重启应用程序以捕获启动跟踪。
-fullClassName启用跟踪信息的包名。
-deeplink $deeplink不适用指定深链接。
rhea.binder启用binder信息增强。
rhea.render启用渲染监控功能。
rhea.io启用I/O监控功能。
rhea.thread启用线程创建监控功能。
rhea.block启用park/unpark/wait/notify监控功能。
rhea.all启用上述所有RheaTrace增强监控功能。
-debug打印调试日志。
--list显示设备支持的类别列表。

技术原理

如果您对RheaTrace 2.0的内部细节感兴趣,可以参考以下文档:RheaTrace 2.0内部原理详解!

已知问题

编号问题建议
1某些自定义ROM可能在获取Perfetto跟踪时遇到失败,错误信息如下: <blockquote>错误:未找到systrace文件:rheatrace.workspace/systemTrace.trace<br/> 提示:您的设备可能不支持perfetto。请尝试使用 -mode simple</blockquote>1. 尝试重启手机并再次尝试。2. 如果问题未解决,请使用 -mode simple 重试。
2不支持Perfetto的设备(主要是8.1之前的系统)无法收集CPU调度等系统信息。尝试使用 -mode simple。
3如果您使用32位APK,可能会因内存不足错误而导致崩溃。要解决此问题,您可以切换到64位包,或者如果必须使用32位,请尝试通过降低bufferSize和配置方法收集阈值来减少虚拟内存使用。这将允许您收集更长时间的跟踪,而不会使用过多的虚拟内存。
4如果因为methodMapping构建到APK中并依赖于mergeAssets而遇到循环依赖问题您可以关闭内置的methodMapping功能。可以通过在Gradle插件配置中将needPackageWithMethodMap设置为false来实现。但是,如果您需要使用btrace功能,则必须使用-m选项手动提供methodMapping的路径。

反馈

我们在RheaTrace 2.0中进行了大量改进,包括更好的错误提示。可能仍然存在一些情况下提示不够准确或消息不够清晰。如果您遇到任何问题,只需在下面的飞书群中告诉我们,我们会尽最大努力帮助您。我们也非常感谢您提供的任何其他反馈或建议,谢谢!

贡献

贡献指南

许可证

Apache许可证

编辑推荐精选

博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

下拉加载更多