examples/

directory
v0.0.18 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 4, 2021 License: Apache-2.0

README

Examples

We set up these examples to help you try out Pyroscope. You'll need docker + docker-compose to run them:

cd python
docker-compose up --build

These are very simple projects where the application is basically one while true loop and inside that loop it calls a slow function and a fast function. Slow function takes about 75% of the time and the fast one takes about 25%. See debug_python_with_pyroscope.md for a full example of how improving one function can decrease overall CPU utilization and ultimately save cut server costs by 66%!

How Pyroscope works

Pyroscope identifies performance issues in your application by continuously profiling the code.

If you've never used a profiler before, then welcome!

If you are familiar with profiling and flame graphs, then you'll be happy to know that Pyroscope:

  • Requires very minimal overhead
  • Can store years of perf data down to 10 second granularity
  • Uses a unique, inverted flame graph for increased readability

There are two main components that allow Pyroscope to run smoothly and quickly:

Pyroscope agent

Every .01 seconds, the Pyroscope agent wraps around your Python, Ruby, or Go application to poll the stacktrace and calculate which function is consuming your CPU resources. pyroscope_diagram_with_logo

Pyroscope Server

Pyroscope records and aggregates what your application has been doing, then sends that data to the Pyroscope server over port :4040(BadgerDB) to be processed, aggregated, and stored for speedy queries of any time range, including:

  • all of 2020
  • that one day last month when that weird thing happened
  • that time you deployed on a Friday and messed up everything without knowing why
  • A random 10 seconds you are only querying to see if Pyroscope is legit

Check out our Demo Page and select any time range to see how quickly Pyroscope works! image

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL