Android bootchart 使用遇到的问题

使用 android bootchart 可以收集 android系统从 init 进程开始到 boot_complete 的时间消耗,以及这段时间内CPU/IO 的消耗。 如何使用这里有说明: https://source.android.com/devices/tech/perf/boot-times

但收集到的数据用 bootchart 来解析时遇到几个问题:

  1. 报错:
Traceback (most recent call last):
  File "/usr/bin/bootchart", line 23, in <module>
    sys.exit(main())
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/main.py", line 137, in main
    render()
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/main.py", line 128, in render
    batch.render(writer, res, options, filename)
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/batch.py", line 39, in render
    surface = make_surface(w,h)
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/batch.py", line 22, in <lambda>
    "png": (lambda w,h: cairo.ImageSurface(cairo.FORMAT_ARGB32,w,h), lambda sfc: sfc.write_to_png(filename)),
cairo.Error: invalid value (typically too big) for the size of the input (surface, pattern, etc.)

这是因为进程树的开始时间计算错误:

/usr/lib/python2.7/dist-packages/pybootchartgui/process_tree.py

def get_start_time(self, process_subtree):
        """Returns the start time of the process subtree.  This is the start
  time of the earliest process.
        """
        if not process_subtree:
            return 100000000; //这个值本意是要比当前进程树中所有的启动时间都大,这样下面的min才能取到当前进程树中的开始时间。但这里这个值小了,所以下面 min 取到的就是 100000000, 因此把这个值再加2个0就好了

        return min( [min(proc.start_time, self.get_start_time(proc.child_list)) for proc in process_subtree] )
  1. 磁盘使用情况数据解析失败:
Traceback (most recent call last)
  File "/usr/bin/bootchart", line 23, in <module>
    sys.exit(main())
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/main.py", line 137, in main
    render()
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/main.py", line 128, in render
    batch.render(writer, res, options, filename)
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/batch.py", line 41, in render
    draw.render(ctx, options, *res)
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/draw.py", line 282, in render
    draw_chart(ctx, IO_COLOR, True, chart_rect, [(sample.time, sample.util) for sample in disk_stats], proc_tree)
  File "/usr/lib/python2.7/dist-packages/pybootchartgui/draw.py", line 201, in draw_chart
    yscale = float(chart_bounds[3]) / max(y for (x,y) in data)
ZeroDivisionError: float division by zero

原因是解析磁盘数据时,bootchart 默认的 /proc/diskstats 格式数据是14列的, 而我这边的环境是18列,所以解析失败,进而导致后面的除数为0 的错误, 把这里改成真实数据的列数就好了:

/usr/lib/python2.7/dist-packages/pybootchartgui/parsing.py
def _parse_proc_disk_stat_log(file, numCpu):
...
  def is_relevant_line(linetokens):
    return len(linetokens) == 14 and re.match(DISK_REGEX, linetokens[2])
...
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容