Grafana Cloud

Explore your infrastructure with Kubernetes Monitoring

Kubernetes Monitoring offers visualization and analysis tools for you to:

  • Evaluate the health, efficiency, and cost of Kubernetes infrastructure components.
  • Analyze historical data as well as forecasts.
  • View predictions created with machine learning.
  • Manage alerts.
  1. Navigate to your Grafana Cloud portal.
  2. In the menu, select the stack you want to work with.
  3. Click the Grafana logo icon.
  4. In the main menu, expand Infrastructure.
    Main menu with Infrastructure selected
    Main menu with Infrastructure selected
  5. Click Kubernetes.
    Kubernetes menu item showing on the main menu
    Kubernetes menu item showing on the main menu

Search for a Kubernetes object

Use search to find any Kubernetes Cluster, Node, namespace, workload, Pod, or container.

Home page search field and search results page
Home page search field and search results page

If the main menu is docked, you can also navigate to Search from the menu.

Explore using the Kubernetes structure

Kubernetes Monitoring pages reflect the hierarchy of Kubernetes objects, so you can begin at any level above containers. Main pages include lists of Clusters, namespaces, workloads, and Nodes.

For example, the Cluster main page shows the list of your Clusters. When you click on a Cluster in the list, it opens the Cluster detail page. That page shows the details for the Cluster along with a list of Nodes within that Cluster.

You can continue to drill into a Node and see the list of Pods for that Node, all the way to the container level.

Navigating from main Cluster list page to container detail page
Navigating from lists to detail pages

There are also main pages for Cluster configuration as well as managing alerts, cost, and efficiency.

You can navigate from the Cluster detail page to the list of workloads or namespaces in that Cluster.

Navigating from Cluster detail page to namespace and workload lists
Navigating from Cluster detail page to namespace and workload lists

For additional navigation tips, refer to Navigation tips for Kubernetes Monitoring.

Start with high-level snapshot

The Kubernetes Overview page gives you a high-level view of your Clusters, usage, and alerts. This page brings to the forefront key data about your infrastructure.

Refine counts of Kubernetes objects and navigate to them

Adjust the time range and filter by Cluster and namespace to narrow and include historical data for:

  • Clusters, Nodes, namespaces, workloads, Pods, and containers
  • Deployed container images
Filtering by Cluster for object count
Filtering by Cluster for object count

After filtering, click the Clusters, Nodes, namespaces, or workloads you want to navigate to.

Jumping from counter on overview page to Node list
Jumping from counter on overview page to Node list

Note

The Overview page calculation uses the most recent data point within your selected time range. The rest of Kubernetes Monitoring also includes objects which are no longer active. For example, a Node can be active and then not active many times throughout a given time range. Therefore, you may see a discrepancy between the count on the Overview page and the count on the list page.

Find usage spikes

Use the time range selector to focus on a time period while looking for patterns or spikes in CPU and memory usage in your Clusters. When spikes occur:

  1. Zoom in on the graph to narrow the time selection.

    Zooming in on graph to change time range
    Zooming in on graph to change time range

  2. Hover over and click the peak of the spike to see the percentage of use compared to capacity. In the following example, the spike shows 46.5% of CPU usage compared to capacity.

    Hovering over spike to show Cluster link
    Hovering over spike to show Cluster link

  3. Click the View link to view the Cluster. The Cluster detail page shows the time range you set when zooming in on the graph.

    Cluster detail page
    Cluster detail page
    You can continue by sorting the list of Nodes in this Cluster by highest CPU usage to investigate the issue causing the spike.

Review and drill into alerts

  1. Sort the Firing Since column of alerts to focus on either the most current or the oldest alerts that are firing.

  2. Click the container or Pod name related to the alert to jump directly to the detail page.

    List of container alerts
    List of container alerts
    Container detail page
    Container detail page

Manage alerts

View and respond to all Kubernetes-related alerts from the Alerts page and the Kubernetes Overview page.

You can also:

Analyze costs

On the Cost page, use the Overview and Savings tabs to gain an understanding what Kubernetes is costing and how you can save. You can see the cost of each item in any list view as well as on the detail pages.

Understand efficiency and resource use

Optimize resource usage and efficiency by:

  • Correlating between average and maximum resource usage to understand performance and troubleshoot stability issues.
  • Observe resource usage for each Kubernetes object.
  • Discover any stranded resources in your fleet.
List of namespaces showing CPU and memory average and maximum data
List of namespaces showing CPU and memory average and maximum data

Throughout Kubernetes Monitoring, resource usage statistics are available for Kubernetes objects.

CPU and memory tabs

On any detail page you can view an overview of CPU and memory usage. You can also click the CPU tab or the Memory tab to view more correlated usage information. For example, the CPU and Memory tabs on the Cluster detail page show:

GPU tabs

View GPU utilization panels on the GPU tabs of Cluster and Node detail pages to answer questions like:

  • Are the Nvidia GPUs inside my Cluster appropriately utilized in relation to tensor cores, encoders, and decoders?
  • Are workloads getting and using the GPU resources that have been made available to me?
GPU tab of Cluster detail page
GPU tab of Cluster detail page

Track persistent storage metrics

Graphs in the storage tab on the Cluster, Namespace, Workload, Node, and Pod detail pages show how persistent volume (PV) storage changes over a specific time range. You can gain insight into:

  • Storage classes of persistent volume claims (PVC)
  • Volume bytes of the requested PVC, which compares requests, data capacity, and usage
  • Volume inodes, comparing capacity with usage
  • The status phase of the PV and PVC, including the binding of the PVC request
  • Throughput to understand how much data is being read and written per second
  • IOPS (Input/Output Operations per Second) to understand how many read and write operations are being performed per second

The PV status on the Pod details page indicates the relationship between persistent volumes and Pods, and also shows the name of the volume, which can change over time.

Graph of PVC storage classes for a Cluster
Graph of PVC storage classes for a Cluster
Graph of PVC volume bytes for namesplaces in a Cluster
Graph of PVC volume bytes for namesplaces in a Cluster

Graphs of throughput and IOPS for a namespace and by workloads within the namespace
Graphs of throughput and IOPS for a namespace and by workloads within the namespace

Learn what’s predicted

CPU and memory prediction can help you ensure resources are available during spikes in usage, as well as help you decrease the amount of unused resources due to over provisioning. To use prediction tools, first enable the Machine Learning plugin.

The following buttons are available in various views. Click them to show a prediction for Clusters, namespaces, workloads, Nodes, Pods, and containers. The time range you select must be at least two hours to use these prediction tools:

  • Predict Mem Usage: Shows a predictive graph for memory usage one week in the future. Calculations are based on metrics from the previous week.

  • Predict CPU: Shows a predictive graph for CPU usage one week in the future. Calculations are based on metrics from the previous week.

    Predict CPU button
    Predict CPU button

    Predictions for Pod CPU Usage
    Predictions for Pod CPU Usage

Detect outlier Pod CPU usage

You can identify any Pods that have CPU usage different from other Pods. For any multi-Pod workload, go to the workload detail page, and review the information in the Overview tab. If there is a Pod in the workload that is an outlier for CPU usage, it is indicated in the outliers by CPU field. Click the link to open Explore and discover the outlier Pod.

Clickable message on workload detail page showing a CPU outlier Pod
Clickable message on workload detail page showing a CPU outlier Pod

Uncover energy usage

On any detail page, click the Energy tab to view the energy usage of:

  • Workloads and namespaces
  • Clusters
  • Nodes
  • Pods
  • Containers
Energy usage for workloads in a namespace for 24 hours
Energy usage for workloads in a namespace for 24 hours

When you configure Kubernetes Monitoring to gather energy metrics, Kepler exposes and gathers metrics, and Alloy collects these metrics.

Energy metrics are separated into these categories:

Analyze historical data

Select a time range to see your historical data for any time frame you choose. As you navigate from page to page, the time range remains the same for period you set until you change it again.

As an example, the Pod optimization section of the Pod detail page shows a time range over several hours. You can use this to understand the historical pattern of CPU usage and memory usage.

Graphs showing Pod bursting over CPU request and bursting above memory requests
Pod optimization view on Pod detail page

Zoom into an area of any graph on the detail pages to narrow the time range selector even further. The time range remains selected until you click Back to default.

Give it a try using Grafana Play
Give it a try using Grafana Play

With Grafana Play, you can explore and see how it works, learning from practical examples to accelerate your development. This feature can be seen on this workload details page set for the last 2 days.

Monitor cron jobs and other job types

You can monitor manual jobs and scheduled (cron) jobs. Use the main menu to find and select All jobs. Use the Cronjobs and Jobs lists to view jobs across all Clusters and Namespaces, based on the time range you choose in the time range selector. You can view:

  • A color-coded status indicator for each job
  • How jobs are distributed and where jobs are placed across the infrastructure
  • For cron jobs:
    • Last succeeded, to verify jobs are completing successfully
    • Last scheduled compared to succeeded, to view any gaps that reveal failed or skipped executions
  • For manual jobs, Pods/completions to track when the job was run
Cronjobs list
Cronjobs list

To further investigate a job, click the job name to open its detail page.

Detail page of a job, open to the **Overview** tab
Detail page of a job, open to the Overview tab

On the job detail page, the Overview tab contains:

  • Status, start time, end time, Pod status phase, logs, and events
  • CPU and memory usage, to identify any over or under provisioning as well spot any gradual increases that indicate memory leaks
  • Container logs for debugging failed runs
  • Events for identifying error messages or unexpected behavior
  • Runs table to track success/failure patterns over time, and understand duration and completion

You can further explore each job’s CPU and Memory tabs for greater insight.

Find deleted Kubernetes objects

You can find deleted Clusters, namespaces, workloads, Nodes, Pods, and containers to understand what occurred in the past. To do so, set the time range selector to a past time period.

The following example shows a time range of the previous 30 days with some Nodes that show no data (also colored in white text). When you click on a Node with no data, you can learn when the Node expired.

Node details page showing Node expiration
Node details page showing Node expiration

Note

Grafana Cloud has a default 30-day limit for queries. If your Kubernetes object was deleted 30 days beyond the current date, use the time range selector to choose a specific 30-day time frame in the past.

Access Nodes in Cloud provider accounts

You can navigate to the EC2 dashboard for Nodes managed by AWS from Kubernetes Monitoring. For example:

  1. Find the EC2 Node by go to Search to search for the Node name.
  2. In the search results, click the Node name to open the Node detail page.
  3. On the far right-hand side of the screen, open the AWS drop-down to see the link to the EC2 instance.
    AWS drop-down menu
    AWS drop-down menu
  4. Click the instance link to open the EC2 overview. Here you can find AWS-specific metadata and other data provided by Cloudwatch metrics.
    Dashboard for AWS EC2 instance
    Dashboard for AWS EC2 instance
  5. To return to the Kubernetes Monitoring view of the Node, click Back to Kubernetes Node.

Discover non-standard workloads

You can find non-standard workloads, including:

  • Argo Rollouts
  • Strimzi Pod sets
  • Unmanaged (or static) Pods
  • CronJobs
  • Bare Pods

Navigate to the Workloads main page, and filter the Type column.

Filtering for workload type
Filtering for workload type

View network bandwidth and saturation

Use the network panels to understand when bandwidth limits are causing network saturation, which can lead to dropped packets. On any detail page for Cluster, namespace, workload, Node, or Pod, click the Network tab to view:

  • Network Bandwidth Rx/Tx: Shows the rate of received and transmitted bytes
  • Network Saturation Rx/Tx dropped packets: Shows rate of received and transmitted packets dropped
  • Network Bandwidth and Network Saturation by Node, workload, or Pod: Shows the bandwidth and saturation by object
    Network bandwidth and saturation panels for a Cluster
    Network bandwidth and saturation panels for a Cluster
Give it a try using Grafana Play
Give it a try using Grafana Play

With Grafana Play, you can explore and see how it works, learning from practical examples to accelerate your development. This feature can be seen on the Network tab of this namespace details page.

View logs and events

From any detail page, click the Logs & Events tab to view the logs and events for that Kubernetes object. You can filter for many dimensions, including:

  • Time period
  • Component
  • Cloud region
  • Error level
Logs for a Cluster
Logs for a Cluster

To see a longer message in the Logs table, hover over the item and click the Inspect value (eye) icon to see the complete message.

Clicking the Inspect value icon to see the full message
Clicking the Inspect value icon to see the full message

Resolve issues with built-in tools

Navigate easily from Kubernetes Monitoring to other capabilities in Grafana Cloud to analyze, troubleshoot, and solve issues.

Start an automated diagnostic

From a Pod, Cluster, namespace, or workload detail page, you can begin an automated investigation by clicking Run Sift investigation. Sift performs a set of automated system checks, and surfaces potential issues in your Kubernetes environment. It then works to identify the root cause of an incident.

Opening a Sift investigation for a namespace
Opening a Sift investigation for a namespace

Access root cause analysis tool

Note

To access root cause analysis tools, enable Asserts on your stack.

You can take troubleshooting deeper by understanding relationships between components and what is occurring between them. Within Kubernetes Monitoring, access RCA Workbench to perform root cause analysis.

Access the RCA Workbench by any of these methods:

Go directly to the connections view in Asserts to view connections between entities.

Jumping to view connections in Asserts
Jumping to view connections in Asserts

Jump to the application layer

On the detail page for a Pod or workload, click View application layer, then Go to Application Observability to navigate directly to more data, such as the service health.

Navigating directly to the Application Observability app
Navigating directly to the Application Observability app

To return to Kubernetes Monitoring, click the browser back button.

View queries to troubleshoot with Explore

To further query data, use any of the Explore buttons available throughout the interface (such as Explore namespaces or Explore alerts). You see a view that provides additional query tools for troubleshooting.

Raw query with options to add, view query history, and inspect query
Raw metrics

Use debug metrics

For any panel, you can open Debug Metrics to see the metrics used for the panel.

If you choose to enable traces when you configure Kubernetes Monitoring, you can easily click to see them.

  1. Click the main menu icon.

  2. Click Explore.

  3. Choose the Tempo data source.

  4. With the TraceQL tab selected, enter your search query.

  5. Click Run query.

    A table of traces appears.

  6. Click a trace to see the detail.

Explore detail page showing table of traces, TraceQL query, and trace graph
View traces

Manage configuration

If you have the admin role, you can manage the configuration of Kubernetes Monitoring by working with:

  • Data source choices
  • Alerts
  • Integration installations
  • Optional custom log queries
  • Configuration instructions for Grafana Kubernetes Monitoring Helm chart to deploy, configure, and keep it up to date

Access more information

Click the documentation links on a page to find more information about what you’re viewing.

Here are some tips and shortcuts for getting around in Kubernetes Monitoring.

Give it a try using Grafana Play
Give it a try using Grafana Play

With Grafana Play, you can explore and see how it works, learning from practical examples to accelerate your development. This feature can be seen on the Kubernetes Monitoring Overview.

Jump between main pages

From any main page, click the icon beside the page title to see the menu of all main pages. Then click the page you want to open.

Clicking next to the page title to reveal navigation menu
Clicking next to the page title to reveal navigation menu

Dock the main menu

To keep the main navigation open:

  1. Click the Grafana logo menu icon.
  2. Click the dock menu icon to keep the main menu open.
Hovering over the dock menu icon
Hovering over the dock menu icon

Filter, sort, and set the time range

Use filters and sorting, along with the time range selector, to target the data you want.

Filtering for a namespace
Filtering for a namespace

Jump to main lists

From the counts on the Kubernetes Overview home page, click All to see that component’s list of items in your Kubernetes fleet.

Clicking the **All** link from the **Kubernetes Overview** page to see a list of all Clusters
Clicking the All link from the Kubernetes Overview page to see a list of all Clusters

Control app refresh

You can control the automatic refresh interval of the GUI as well as disable the auto refresh.

Menu for controlling automatic refresh and refresh interval
Menu for controlling automatic refresh and refresh interval

Use color cues

Throughout the views in Kubernetes Monitoring, you see color used as an additional means of indicating status or condition. For example, sometimes text is a different color for Pod status:

List of workloads with the status of running showing in green
Color coding

TextColorComments
FailedRedFailed Pod
RunningGreenHealthy Pod
RunningRedPod is failing to start
SucceededGreenJob Pod successfully run
UnknownWhitePod status is unknown
WaitingYellowPod is waiting because of startup, such as Pod initializing or container creating
WaitingRedPod is waiting because of a problem, such as crash loop back off or image pull back off

For more information on Pod status, refer to the Kubernetes documentation on Pod lifecycle.

The following table describes the color indicators for resource capacity and the state of resource usage:

Usage ColorsUsageComments
Green60-90% of maximumThis is the ideal state of resource usage.
YellowBelow 60%Low usage percentages indicate that the item might be over provisioned.
Red90%+Your resource usage is close to or above its configured capacity.