Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/evanhempel/python-flamegraph
Statistical profiler which outputs in format suitable for FlameGraph (http://www.brendangregg.com/flamegraphs.html)
https://github.com/evanhempel/python-flamegraph
Last synced: 3 months ago
JSON representation
Statistical profiler which outputs in format suitable for FlameGraph (http://www.brendangregg.com/flamegraphs.html)
- Host: GitHub
- URL: https://github.com/evanhempel/python-flamegraph
- Owner: evanhempel
- License: unlicense
- Created: 2015-03-08T23:21:46.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2020-02-11T09:57:21.000Z (almost 5 years ago)
- Last Synced: 2024-10-01T19:10:26.931Z (4 months ago)
- Language: Python
- Homepage:
- Size: 192 KB
- Stars: 394
- Watchers: 9
- Forks: 55
- Open Issues: 11
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
- starred-awesome - python-flamegraph - Statistical profiler which outputs in format suitable for FlameGraph (http://www.brendangregg.com/flamegraphs.html) (Python)
README
A simple statistical profiler which outputs in format suitable for FlameGraph_.
INSTALL:
--------Simply run::
pip install git+https://github.com/evanhempel/python-flamegraph.git
USAGE:
------Run your script under the profiler::
python -m flamegraph -o perf.log myscript.py --your-script args here
Or, run the profiler from your script::
flamegraph.start_profile_thread(fd=open("./perf.log", "w"))
Run Brendan Gregg's FlameGraph_ tool against the output::
flamegraph.pl --title "MyScript CPU" perf.log > perf.svg
Enjoy the output:
.. image:: docs/attic-create.png
:alt: Attic create flame graph
:width: 679
:height: 781
:align: center**Filtering**
Sometimes you may want to exclude a method
(for example in a server the method that waits for a new request)
or you may want to profile only a subset of your code
(a particular method and its children which are performance critical).Filtering can be done by passing a python regular expression to the
``-f`` or ``--filter`` command line option
which will restrict output to only those lines which match.
Filtering is done against the entire line so you can filter by
function name, thread name, both, or even by
more complex filters such as function ABC calls DEF (``ABC.*DEF``).Alternatively since the output is stackframes each on a line by itself,
this can simply be done with a simple grep filter.::Exclude:
grep -v waiting_method perf.log > removed_waiting.log
Include:
grep function_name perf.log > filtered.log
Then run the flamegraph.pl script against the filtered file.
.. figure:: docs/ycanta-full.png
:alt: yCanta webapp full profile of PDF export
:align: centerFull profile output of yCanta_ webapp PDF export. Most time is
spent in wait state and graph is not very helpful... figure:: docs/ycanta-pdf.png
:alt: yCanta webapp filtered for PDF export format function.
:align: centerFiltered profile output of yCanta_ webapp PDF export. Filtering was on the
pdf format function so time spent in wait state has been excluded and the
graph is now helpful... _FlameGraph: http://www.brendangregg.com/flamegraphs.html
.. _yCanta: https://github.com/yCanta/yCanta