Grafana Cloud

Concepts

To use profiling, you should understand these concepts:

  • Profile data hierarchy
  • Profile types
  • Labels
  • Flame graphs

Profile data hierarchy

Each profile has data for services. A service can be one of the processes running on your system or application.

Each service has multiple profile types, such as CPU, memory, exceptions, and locks. These profiles provide details about the processes in a service.

  • Service: This is the main application or system you are monitoring. For example, it could be an online shopping platform, a social media application, or a cloud storage service.
    • Profile type: You can monitor each service through different profile types, each focusing on a specific performance aspect. Example profile types:
      • CPU
      • allocated memory
      • in-use memory
      • goroutines
    • Labels: These are tags or descriptors that provide additional context to the profile types. Labels help categorize and filter the data for easier analysis. For example:
      • Namespace:
      • Pod
      • Instance
      • IP
      • Region

Profile types

Profile types refer to different dimensions of application performance analysis, focusing on specific aspects like CPU usage, memory allocation, or thread synchronization.

For more information, refer to Understand profiling types.

Profile typeWhat it showsWhen to use
CPU profilingMeasures the amount of CPU time consumed by different parts of your application codeTo identify and optimize CPU-intensive functions
Memory allocationTracks the amount and frequency of memory allocations by the applicationFor identifying and optimizing memory usage patterns
GoroutineMeasures the usage and performance of lightweight routines in GoEspecially useful in Go applications for concurrency management
Contentions (Mutex)Mutex profiling involves analyzing mutex (mutual exclusion) locks, used to prevent simultaneous access to shared resources.To optimize thread synchronization and reduce lock contention
BlockMeasures the frequency and duration of blocking operations, where a thread is paused or delayedTo identify and reduce blocking delays

Labels

Labels help identify parts of profiling data. For example, labels identify Kubernetes Pod names, namespaces, repositories, and references. You can also create custom labels.

This feature is crucial for identifying performance anomalies and understanding the behavior of different application segments under various conditions.

Labels view in Profiles Drilldown

Flame graphs

A fundamental aspect of continuous profiling is the flame graph, a convenient way to visualize performance data. These graphs provide a clear, intuitive understanding of resource allocation and bottlenecks in the application.

You can use a flame graph visualization if you need to:

  • Identify any performance hot spots to find where code optimizations may be needed.
  • Diagnose the root cause of any performance degradation.
  • Analyze the behavior of complex systems, including distributed systems or microservices architectures.

To learn more, refer to the Flame graph documentation. To learn more about the flame graph user interface, refer to Flame graph visualization panel.

An example flame graph with an explanation generated by Flame graph AI