Giter VIP home page Giter VIP logo

saanvi-tayal / pyroscope Goto Github PK

View Code? Open in Web Editor NEW

This project forked from grafana/pyroscope

0.0 0.0 0.0 95.27 MB

Continuous Profiling Platform. Debug performance issues down to a single line of code

Home Page: https://grafana.com/oss/pyroscope/

License: GNU Affero General Public License v3.0

Shell 0.39% JavaScript 0.56% C 0.05% Go 68.05% TypeScript 26.16% CSS 0.83% Makefile 0.74% HTML 0.05% Dockerfile 0.05% SCSS 1.73% Jsonnet 1.32% Mustache 0.07%

pyroscope's Introduction

Pyroscope

ci JS Tests Status Go Report License: AGPLv3 FOSSA Status Latest release DockerHub GoDoc

๐ŸŒŸ What is Grafana Pyroscope?

Grafana Pyroscope is an open source continuous profiling platform. It will help you:

  • Find performance issues and bottlenecks in your code
  • Use high-cardinality tags/labels to analyze your application
  • Resolve issues with high CPU utilization
  • Track down memory leaks
  • Understand the call tree of your application
  • Auto-instrument your code to link profiling data to traces

๐Ÿ”ฅ Pyroscope Live Demo ๐Ÿ”ฅ

Pyroscope GIF Demo

๐ŸŽ‰ Features

  • Minimal CPU overhead
  • Horizontally scalable
  • Efficient compression, low disk space requirements
  • Can handle high-cardinality tags/labels
  • Calculate the performance "diff" between various tags/labels and time periods
  • Advanced analysis UI

๐Ÿ’ป Quick Start: Run Pyroscope Locally

Homebrew

brew install pyroscope-io/brew/pyroscope
brew services start pyroscope

Docker

docker run -it -p 4040:4040 grafana/pyroscope

For more documentation on how to configure Pyroscope server, see our server documentation.

Send data to server via Pyroscope agent (language specific)

For more documentation on how to add the Pyroscope agent to your code, see the agent documentation on our website or find language specific examples and documentation below:


Golang

Documentation
Examples

Java

Documentation
Examples

Python

Documentation
Examples

Ruby

Documentation
Examples

NodeJS

Documentation
Examples

Dotnet

Documentation
Examples

eBPF

Documentation
Examples

Rust

Documentation
Examples

Deployment Diagram

deployment_diagram

Documentation

For more information on how to use Pyroscope with other programming languages, install it on Linux, or use it in production environment, check out our documentation:

Downloads

You can download the latest version of pyroscope for macOS, linux and Docker from our Releases page.

Supported Languages

  • Go (via pprof)
  • Python (via py-spy)
  • Ruby (via rbspy)
  • Linux eBPF
  • Java (via async-profiler)
  • Rust (via pprof-rs)
  • .NET
  • PHP (via phpspy)
  • Node

Let us know what other integrations you want to see in our issues or in our slack.

Credits

Pyroscope is possible thanks to the excellent work of many people, including but not limited to:

  • Brendan Gregg โ€” inventor of Flame Graphs
  • Julia Evans โ€” creator of rbspy โ€” sampling profiler for Ruby
  • Vladimir Agafonkin โ€” creator of flamebearer โ€” fast flamegraph renderer
  • Ben Frederickson โ€” creator of py-spy โ€” sampling profiler for Python
  • Adam Saponara โ€” creator of phpspy โ€” sampling profiler for PHP
  • Alexei Starovoitov, Brendan Gregg, and many others who made BPF based profiling in Linux kernel possible
  • Jamie Wong โ€” creator of speedscope โ€” interactive flamegraph visualizer

Contributing

To start contributing, check out our Contributing Guide

Thanks to the contributors of Pyroscope!

pyroscope's People

Contributors

petethepig avatar cyriltovena avatar simonswine avatar pyroscopebot avatar eh-am avatar rperry2174 avatar kolesnikovae avatar korniltsev avatar aocenas avatar dogfrogfog avatar abeaumont avatar pavelpashkovsky avatar hi-rustin avatar louisinflow avatar darrenjaneczek avatar shaleynikov avatar 09jvilla avatar joey-grafana avatar eve832 avatar iolivernguyen avatar adrk avatar jdbaldry avatar alonlong avatar loggy avatar richih avatar cjsampson avatar cristiangreco avatar bryanhuhta avatar robbymilo avatar ekpatrice avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.