perf_to_profile binary can be used to turn a perf.data file, which is
generated by the linux profiler, perf, into a profile.proto file which can be
visualized using the tool pprof.
For details on pprof, see https://github.com/google/pprof
THIS IS NOT AN OFFICIAL GOOGLE PRODUCT
Prerequisites to build
sudo apt-get -y install g++ git libelf-dev libcap-dev
Compile and Test
To install all dependences and build the binary, run the following commands. These were tested on Ubuntu 14.04 LTS:
Install bazel by following the instructions here.
Install dependencies and build perf_to_profile using bazel
git clone https://github.com/google/perf_data_converter.git cd perf_data_converter bazel build src:perf_to_profile
perf_to_profile binary in a place accessible from your PATH (e.g.
There are a small number of tests that verify the basic functionality. To run these, after successful compilation, run:
bazel test src:all bazel test src/quipper:all
Note: Executables generated using
bazel build are available under the
Profile a command using perf, for example:
perf record /bin/ls
Recent versions of pprof will automatically invoke
pprof -web perf.data
Compile and test with Makefiles
SUPPORT FOR MAKE FILES WILL BE REMOVED AFTER MAY 2018
These were tested on Debian GNU/Linux 8 (jessie):
sudo apt-get -y install autoconf automake libssl-dev make libtool pkg-config git clone --recursive https://github.com/google/perf_data_converter.git cd perf_data_converter/src make perf_to_profile
If you already have protocol buffers and googletest installed on your system, you can compile using your local packages with the following commands:
sudo apt-get -y install autoconf automake libssl-dev make libtool pkg-config git clone https://github.com/google/perf_data_converter.git cd perf_data_converter/src make perf_to_profile
- To run test, after successful compilation, run:
make check clean make check clean -C quipper/ -f Makefile.external
We appreciate your help!
Note that perf data converter and quipper projects do not use GitHub pull requests, and that we use the issue tracker for bug reports.