zoukankan      html  css  js  c++  java
  • 如何在电脑上监控安卓手机应用程序运行的CPU、内存等资源情况,并做成曲线图

      做测试工程师十多年,手机测试接触太少,请叫我小白吧。当我们拿到一个趋于成熟的安卓应用程序APP,老板发话了:帮我监控下这个APP的运行情况,我要知道这个APP短时间内执行某些操作,在手机上的内存、CPU占比情况,并做成曲线图。平常我们抱着手机玩的时候,有哪位朋友会一直关注自己手机APP的性能呢,答案就是:老板。带着这个问题,小白的我也是摸摸头脑,想想办法吧。

    试过了几种不同的方法:

    1、直接在手机上安装**监控应用,但效果不理想,果断放弃;

    2、在电脑上安装了DDMS(Dalvik Debug Monitor Service),并成功连接手机,打开应用,终于看到连接进来了,有点小开心

    选择相应的应用,然后点击Cause GC之后就可以看到我们应用的内存情况,如下图:

    虽然看到了内存的使用情况,但是没办法时时自动变化,形成曲线图,而且也没有显示CPU占比,好吧,只能再次放弃了。

    3、继续寻找其他的办法,就想到了使用adb shell,最终成功解决了,以下详细介绍如何使用。

    一、电脑要先安装adb环境

    安装过程详见我以往写的博客https://www.cnblogs.com/bzdmz/p/10358152.html

    确保adb命令可以正常使用。

    二、打开APP进行监控

    1、打开电脑运行cmd,打开运行窗口

    2、进入shell脚本模式

    D:android>adb shell

    3、打开APP,并在步骤2的窗口运行以下命令

    PD1616B:/ $ top -d 1 |grep com.test.cc > /sdcard/test_01.log

    -d 1:代表每1秒取一次数据

    com.test.cc 为应用程序的包名,即只监控这个应用程序

    也可以PD1616B:/ $ top -d 1 -p 8398> /sdcard/test_01.log

     -p 8398:即这个APP的进程号,不管你用哪种方法,只要确认监控的包没错即可。

     > /sdcard/test_01.log:将结果输入到/sdcard/路径下的test_01.log文件里

    4、结束抓包,直接用ctrl + c

    5、退出shell模式

    PD1616B:/ $ exit

    6、回到命令窗口,将文件导出到电脑

    D:android>adb pull /sdcard/test_01.log

    [100%] /sdcard/test_01.log

    7、在excel打开,并对数据进行过滤,再做成图表

    注意这里使用分隔符号

    第二步使用空格隔开

    第三步,可根据需要,把一些不需要的列,跳过即可

    导进来的数据很乱,可进行整改,最后可调成为如下:

    最后再将CPU和MEM做成图表的形势:

    选中列数据,然后插入图表,搞定。

    8、如果觉得第7步操作太麻烦,而且很浪费时间,可以使用以下方法做成图表:

    1)将文件上传到linux机器上

    2)使用命令将CPU和内存数值读取出来,然后再放到excel,做成曲线图,完美,是不是感觉有点火箭般的速度了,

    当然小白也是吃过苦的,因为前面第7步,要做表格的整理,实在太慢了,所以想到这个方法。

    获取内存%值:

    cat test_01.log   |grep '8398' |awk '{print $10}'

    获取CPU%值:

    cat test_01.log   |grep '8398' |awk '{print $9}'

     整个过程就是这么的辛酸,所以总结了一下,然后对大家有所帮助,如有高手还有其他更快捷的方法,欢迎留言赐教!

    备注:此博客为本人原创,如有转载请注明出处。

  • 相关阅读:
    Shell 脚本学习 — 简单的执行跟踪
    CentOS — 安装Git客户端
    Linux — cat 命令的使用方法
    关于“分叉/联接方案”的一般做法
    读书笔记 —— 《MySQL技术内幕 InnoDB存储引擎》
    MySQL InnoDB 索引
    CentOS — MySQL备份 Shell 脚本
    CI system/libraries/Session.php
    WinForm 处理未处理的异常 Application.ThreadException + AppDomain.CurrentDomain.UnhandledException
    重构案例1 — ECShop (lib_common.php build_url 函数)
  • 原文地址:https://www.cnblogs.com/bzdmz/p/12345295.html
Copyright © 2011-2022 走看看