Application 效能分析有妙招 — 使用 perf 走天下(转载)
转载:http://tech.mozilla.com.tw/posts/1803/application-%E6%95%88%E8%83%BD%E5%88%86%E6%9E%90-%E4%BD%BF%E7%94%A8-perf
在手機上面,Application 的實作往往會影響到效能好壞以及是否夠省電,其中 Application 的 CPU 使用量會是一個非常關鍵的因素。
以下就拿使用 Firefox OS 的手機來做舉例說明,首先透過下面的 top 指令,可以看到整體 System 以及 Application 的 CPU 使用量,有助於了解 System 或者是 Application 的負載。
peter@pchang:~$ adb shell top -s cpu -m -d
User %, System %, IOW %, IRQ %
User + Nice + Sys + Idle + IOW + IRQ + SIRQ = PID PR CPU% S #THR VSS RSS PCY UID Name
% R 180304K 60156K fg root /system/b2g/b2g
% R 85824K 34104K fg app_483 /system/b2g/plugin-container
% R 1056K 408K fg root top
為了要進一步分析 Application 的效能瓶頸,可以使用 Linux 上分析的工具, perf (Download from Tegra Android Toolkit)。
Perf 是根據 Linux Kernel 已經定義的 perf_event 來紀錄程式運作的過程,所以只要是 Linux based
system 都可以支援,包含 Android/Firefox OS phone。目前 perf_event 在 Linux Kernel
上預設為啓動,所以使用 perf 只要準備好 Application debug symbols 就可以來進行分析。有興趣的朋友可以參考perf kernel support,來進一步確定你的手機是否有啟動 perf_event。
Perf 上也有類似 top 指令,可以看到整體 System 的負載,譬如下面的結果,就可以看到 WebGLContext::Conver 佔用了最多 CPU 資源。
peter@pchang:~$ adb shell perf top -------------------------------------------------------------------------------
PerfTop: irqs/sec kernel:24.9% exact: 0.0% [1000Hz cycles], (all, CPUs)
------------------------------------------------------------------------------- samples pcnt function DSO
_______ _____ _____________________________ ______________________ 697.00 50.6% mozilla::WebGLContext::Conver /system/b2g/libxul.so
424.00 30.8% yamato_tile_texture libGLESv2_adreno200.so
124.00 9.0% yamato_untile_texture libGLESv2_adreno200.so
26.00 1.9% rb_surface_read libGLESv2_adreno200.so
11.00 0.8% mozilla::gl::SwapRAndBCompone /system/b2g/libxul.so
5.00 0.4% yamato_texfmt_to_pixfmt_for_m libGLESv2_adreno200.so
也可以透過 perf record/perf report ,來針對特定的 Application 做負載的分析。不過在分析之前,需要準備除錯用的 gecko modules 和對應的 debug symbols。以 Firefox OS 為範例,先做下面的修改,然後重新編譯和取代 gecko modules 到手機上,這樣是為了把 debug symbols 放到編譯好的 gecko modules,之後才能得到詳盡的分析結果。
peter@pchang:~/B2G/gonk-misc$ git diff ./default-gecko-config
diff --git a/default-gecko-config b/default-gecko-config
index c14919a..9a18176
--- a/default-gecko-config
+++ b/default-gecko-config
@@ -, +, @@ ac_add_options --enable-debug-symbols
if [ "${B2G_DEBUG:-0}" != "" ]; then
ac_add_options --enable-debug
fi
+ac_add_options --enable-profiling if [ "${B2G_NOOPT:-0}" != "" ]; then
透過下面的指令把 debug symbols 存放在 tmp folder 下面。
cp -pr out/target/product/device_name/system/ /tmp/b2g_perf/system/
cp -pr out/target/product/device_name/symbols/system/ /tmp/b2g_perf/system/
cp -pr objdir-gecko/dist/bin/b2g /tmp/b2g_perf/system/b2g/
cp -pr objdir-gecko/dist/lib/*.so /tmp/b2g_perf/system/b2g/
接下來可以開始分析 Application 運作上的瓶頸。
Perf record 會針對 Application 記錄 20 秒的運作訊息,接著把記錄的資料從手機上下載出來。
最後使用 perf report 就可以看到使用 CPU 資源最多的函式名稱,接下來開發者就可以開始進行評估是否有改善的計劃讓 Application 運行的更快更省電。
peter@pchang:~$ adb shell perf record -p pid -o /data/local/perf.data sleep
peter@pchang:~$ adb pull /data/local/perf.data /tmp/b2g_perf/ peter@pchang:~$ perf report --symfs=/tmp/b2g_perf/system/ --sort dso,symbol 71.38% libxul.so [.] mozilla::WebGLContext::Conver
15.28% [ath6kl_sdio] [k] 0x106fd7c
7.40% libGLESv2_adreno200.so [.] yamato_tile_texture
1.81% libc.so [.] memcpy
...
Perf 還有更多的功能,有興趣的讀者可以參考下面的連結。
https://perf.wiki.kernel.org/index.php/Tutorial
Application 效能分析有妙招 — 使用 perf 走天下(转载)的更多相关文章
- 《构建之法》教学笔记——Python中的效能分析与几个问题
<构建之法:现代软件工程>中第2章对效能分析进行了介绍,基于的工具是VSTS.由于我教授的学生中只有部分同学选修了C#,若采用书中例子讲解,学生可能理解起来比较困难.不过所有这些学生都学习 ...
- 【Android 应用开发】 Application 使用分析
博客地址 : http://blog.csdn.net/shulianghan/article/details/40737419 代码下载 : Android 应用 Application 经典用法; ...
- python实现四则运算和效能分析
代码github地址:https://github.com/yiduobaozhi/-1 PSP表格: 预测时间(分钟) planning 计划 15 Estimate 估计这个任务需要多少时间 10 ...
- python词频统计及其效能分析
1) 博客开头给出自己的基本信息,格式建议如下: 学号2017****7128 姓名:肖文秀 词频统计及其效能分析仓库:https://gitee.com/aichenxi/word_frequenc ...
- C#词频统计 效能分析
在邹老师的效能分析的建议下对上次写过的词频统计的程序进行分析改进. 效能分析:个人很浅显的认为就是程序的运行效率,代码的执行效率 1.VS 提供了自带的分析工具:performance tool (性 ...
- 第五次作业——python效能分析与几个问题(个人作业)
第五次作业--效能分析与几个问题(个人作业) 前言 阅读了大家对于本课程的目标和规划之后,想必很多同学都跃跃欲试,迫不及待想要提高自身实践能力,那么就从第一个个人项目开始吧,题目要求见下. 阅读 阅读 ...
- 《软件工程和Python》PYTHON效能分析和Django
资料汇总网站:http://www.yzhiliao.com/my/course/55 一..作业下面两个题目任选一题: (1)运用jieba库分词(或者你喜欢的其他库),并把代码发到git上去(不发 ...
- 效能分析——词频统计的java实现方法的第一次改进
java效能分析可以使用JProfiler 词频统计处理的文件为WarAndPeace,大小3282KB约3.3MB,输出结果到文件 在程序本身内开始和结束分别加入时间戳,差值平均为480-490ms ...
- Application 使用分析
一. Application 分析 1. Application 简介 (1) Application 概念 Application 概念 : Application 属于组件范畴; -- 本质 : ...
随机推荐
- GDKOI2018游记
D0 开开心心去酒店,在Vanda,资磁,然而和其他人住的比较远,不资磁. 开开心心打开玩具熊,吓尿了..第四部贼难. 晚上看了看网络流,1点才睡.3点多好像梦到玩具熊被吓醒,4点继续睡,6点起. D ...
- Memcached 管理与监控工具 MemAdmin
MemAdmin是一款可视化的Memcached管理与监控工具,基于 PHP5 & JQuery 开发,体积小,操作简单. 主要功能: 服务器参数监控:STATS.SETTINGS.ITEMS ...
- CodeForces 429B【dp】
题意: 在一个n*m的矩阵中有两只虫子,一只从左上角向右下角移动,另外一只从左下角向右上角移动. 要求: 1.第一只虫子每次只能向左或者向下移动一格,另外一只只能向上或者向右移动一格. 2.两只虫子的 ...
- @Aspect注解无效
Pointcut的execution配置正确的话,检查下,是否加了以下jar包 <!-- http://mvnrepository.com/artifact/org.aspectj/aspect ...
- eclipse导入maven工程步骤
转自:http://jingyan.baidu.com/article/cbf0e500a6e3252eaa2893c1.html 感谢作者 步骤一 : 选择 “Import”操作 有两个途径可以选择 ...
- eclipse默认指定项目的编译器版本
eclipse 提示 @Override must override a superclass method 问题解决 今天新换了一个Eclipse 版本: Build id: 20140224-06 ...
- 使用POI操作Excel时new XSSFWorkbook ()报错java.lang.NoSuchMethodError解决方式
使用最新的POI3.11时,在执行 Workbook workBook = new XSSFWorkbook ();这段代码时出现错误: java.lang.NoSuchMethodError: j ...
- Qt Quick 图像处理实例之美图秀秀(附源代码下载)
在<Qt Quick 之 QML 与 C++ 混合编程具体解释>一文中我们解说了 QML 与 C++ 混合编程的方方面面的内容,这次我们通过一个图像处理应用.再来看一下 QML 与 C++ ...
- python的线程thread笔记
python的线程是用thread和threading来实现的.其中利用threading会更好,因为thread没有线程保护,当主线程退出了之后,子线程也会被强行退出.threading支持守护线程 ...
- UVA 10288 - Coupons(概率递推)
UVA 10288 - Coupons option=com_onlinejudge&Itemid=8&page=show_problem&category=482&p ...