Please note that User Registration has been temporarily disabled due to a recent increase in automated registrations. If anyone needs an account, please request one here: RequestAccount. Thanks for your patience!--Wmat (talk)
Please email User:Wmat if you experience any issues with the Request Account form.

Difference between revisions of "Bootchart"

From eLinux.org
Jump to: navigation, search
(Added link to new page for bootchartd usage.)
m (move image from page 'Using_bootchartd_on_SH7785LCR_Board')
 
(8 intermediate revisions by 5 users not shown)
Line 2: Line 2:
  
 
== Research & Presentations ==
 
== Research & Presentations ==
 +
=== Timechart ===
 +
 +
* Tool introduced on [http://blog.fenrus.org/?p=5 Arjan Van de Ven's blog]
 +
* Now available in the mainline Linux kernel. It uses the 'perf' infrastructure. Hence, you need a recent enough kernel (2.6.32 or later).
 +
* See [http://lxr.free-electrons.com/source/tools/perf/builtin-timechart.c tools/perf/builtin-timechart.c] and [http://lxr.free-electrons.com/source/tools/perf/Documentation/perf-timechart.txt tools/perf/Documentation/perf-timechart.txt] in the kernel sources for details.
 +
 
=== Bootchart-Lite ===
 
=== Bootchart-Lite ===
 
* [http://tree.celinuxforum.org/CelfPubWiki/JapanTechnicalJamboree16?action=AttachFile&do=get&target=bootchart-lite-en.pdf bootchart-lite-en.pdf] Presentation by Shuuji Miyake of Fujitsu Software Technologies Limited, about bootchart deficiencies in the embedded space and ideas for fixing them.
 
* [http://tree.celinuxforum.org/CelfPubWiki/JapanTechnicalJamboree16?action=AttachFile&do=get&target=bootchart-lite-en.pdf bootchart-lite-en.pdf] Presentation by Shuuji Miyake of Fujitsu Software Technologies Limited, about bootchart deficiencies in the embedded space and ideas for fixing them.
Line 17: Line 23:
  
 
=== EmBootchart ===
 
=== EmBootchart ===
* [http://tree.celinuxforum.org/CelfPubWiki/ELC2006Presentations?action=AttachFile&do=get&target=VisualizingResUsageDuringBoot.pdf Visualizing Resource Usage During Boot] Presentation on 'embootchart' by Matthew Klahn and Moosa Muhammad of Motorola about bootchart deficiencies in the embedded space, and a program (unfortunately never published) to fix them.
+
* [[Media:VisualizingResUsageDuringBoot.pdf|Visualizing Resource Usage During Boot]] - Presentation on 'embootchart' by Matthew Klahn and Moosa Muhammad of Motorola about bootchart deficiencies in the embedded space, and a program (unfortunately never published) to fix them.
  
 
=== BusyBox ===
 
=== BusyBox ===
Line 34: Line 40:
 
  Under PID 1: start background logging, then execute $bootchart_init, /init, /sbin/init
 
  Under PID 1: start background logging, then execute $bootchart_init, /init, /sbin/init
 
  This makes it possible to start bootchartd even before init by booting kernel with:
 
  This makes it possible to start bootchartd even before init by booting kernel with:
  init=/bin/bootchartd bootchart_init=/path/to/regular/init
+
  init=/sbin/bootchartd bootchart_init=/path/to/regular/init
 +
 
 +
Note that if you're using an initramfs, you'll need
 +
rdinit=/sbin/bootchartd
 +
instead of
 +
init=/sbin/bootchartd
 +
 
 +
Note also that bootchartd tries to create a gzipped tarball, so you either need a full tar with gz support, or you need to enable FEATURE_SEAMLESS_GZ in busybox. If 'tar -z' is not working, bootchartd will not produce output.
  
 
==== To use ====
 
==== To use ====
Line 40: Line 53:
 
host machine, and use bootchart to produce a graphic chart of the boot sequence.
 
host machine, and use bootchart to produce a graphic chart of the boot sequence.
  
Also see the following page describing a sample usage:
+
The host 'bootchart' provided by Ubuntu-based hosts uses [http://code.google.com/p/pybootchartgui/ pybootchartgui] to generate a graph from the collected data. However, that version of pybootchartgui does not work well with the data generated by busybox bootchartd. A newer project [https://github.com/mmeeks/bootchart bootchart2] has improved pybootchartgui and included it in their sources, and this works fine with busybox bootchartd data.
* [[Using bootchartd on SH7785LCR Board]]
+
 
 +
After downloading bootchart2 and running 'make', you can generate a graph (bootchart.png) with:
 +
  /path/to/bootchart2/pybootchartgui.py bootlog.tgz
 +
 
 +
An example graph, generated in a different way, is shown below:
 +
 
 +
[[File:Bootchart.png]]
  
 
== Related projects ==
 
== Related projects ==
Line 47: Line 66:
 
A related project is a set of [[System Tap]] scripts to provide information about boot time.
 
A related project is a set of [[System Tap]] scripts to provide information about boot time.
 
See [http://people.redhat.com/berrange/systemtap/bootprobe/ Bootprobe]
 
See [http://people.redhat.com/berrange/systemtap/bootprobe/ Bootprobe]
 +
 +
=== Updated Fork ===
 +
 +
Bootchart has been forked and updated and can be found on github https://github.com/mmeeks/bootchart (Main changes: no java, better visualization)
 +
 +
Another fork (the same?) can be found here: [http://foo-projects.org/~sofar/bootchart/ Updated Bootchart]
  
 
[[Category:Boot Time]]
 
[[Category:Boot Time]]

Latest revision as of 17:22, 27 October 2013

Bootchart is a tool for performance analysis and visualization of the Linux boot process. Resource utilization and process information are collected during the user-space portion of the boot process and are later rendered in a PNG, SVG or EPS encoded chart. For embedded systems several developers have tried to use bootchart to analyze boot time, but problems arose. There have been several efforts to modify bootchart to make it more useful for embedded development.

Research & Presentations

Timechart

Bootchart-Lite

svn checkout http://bootchart-lite.googlecode.com/svn/trunk/ bootchart-lite-read-only

ubootchart

Like Bootchart Lite, an implementation of the ideas from "embootchart".

EmBootchart

  • Visualizing Resource Usage During Boot - Presentation on 'embootchart' by Matthew Klahn and Moosa Muhammad of Motorola about bootchart deficiencies in the embedded space, and a program (unfortunately never published) to fix them.

BusyBox

Busybox has a C implementation of bootchartd. It compiles to less than 40k (static uclibc i386 build). It will be available in the busybox-1.17.0 release. Please send bug reports, improvements to busybox mailing list.

Usage: bootchartd start [PROG ARGS]|stop|init

Options:
start: start background logging; with PROG, run PROG, then kill logging with USR1
stop: send USR1 to all bootchartd processes
init: start background logging; stop when getty/xdm is seen (for init scripts)
Under PID 1: start background logging, then execute $bootchart_init, /init, /sbin/init
This makes it possible to start bootchartd even before init by booting kernel with:
init=/sbin/bootchartd bootchart_init=/path/to/regular/init

Note that if you're using an initramfs, you'll need

rdinit=/sbin/bootchartd

instead of

init=/sbin/bootchartd

Note also that bootchartd tries to create a gzipped tarball, so you either need a full tar with gz support, or you need to enable FEATURE_SEAMLESS_GZ in busybox. If 'tar -z' is not working, bootchartd will not produce output.

To use

To use this, capture the bootchart information using bootchartd, then transfer the information to your host machine, and use bootchart to produce a graphic chart of the boot sequence.

The host 'bootchart' provided by Ubuntu-based hosts uses pybootchartgui to generate a graph from the collected data. However, that version of pybootchartgui does not work well with the data generated by busybox bootchartd. A newer project bootchart2 has improved pybootchartgui and included it in their sources, and this works fine with busybox bootchartd data.

After downloading bootchart2 and running 'make', you can generate a graph (bootchart.png) with:

 /path/to/bootchart2/pybootchartgui.py bootlog.tgz

An example graph, generated in a different way, is shown below:

Bootchart.png

Related projects

SystemTap Scripts

A related project is a set of System Tap scripts to provide information about boot time. See Bootprobe

Updated Fork

Bootchart has been forked and updated and can be found on github https://github.com/mmeeks/bootchart (Main changes: no java, better visualization)

Another fork (the same?) can be found here: Updated Bootchart