Menu
Grafana Cloud RSS

Adaptive Logs overview

Adaptive Logs is a cost optimization feature in Grafana Cloud that lets you identify and reduce unneeded log volume. Most companies generate more logs than they need. By not storing logs that aren’t valuable to you, you can significantly reduce the number of logs you need to look through to find what you are looking for. Adaptive Logs makes recommendations which identify a percentage of logs which can be dropped based on query usage within your Cloud Logs environment.

How Adaptive Logs works

Adaptive Logs analyzes individual log lines, categorizes them into groups of matching patterns, then tracks the number of occurrences of each pattern match. It then looks at all query behavior in your Grafana Cloud Logs instance, and identifies how often log lines matching those patterns have been queried. Finally, Adaptive Logs presents a percentage of log lines per pattern that can be dropped with minimal impact, based on how often they are being queried.

You can review, edit, and accept Adaptive Logs recommendations in the Grafana Cloud Cost Management portal.

Based on applied recommendations, logs will be dropped upon ingestion by Grafana Cloud. Logs are dropped server-side, after they have been sent, but before they are indexed and made available to query. You will not be billed by Grafana Labs for these dropped logs.

Adaptive Logs workflow

The general workflow for using Adaptive Logs is as follows:

  1. Review recommendations.
  2. Select from the recommendations provided. You may edit recommendations as needed.
  3. Apply recommendations.

Review recommendations

  1. To access the Adaptive Logs user interface, in Grafana Cloud navigate to Home > Administration > Cost management > Logs cost management.
  2. Under Optimize, click Adaptive Logs. If you have already applied one or more recommendations, the Adaptive Logs screen shows the drop rate currently being applied to each recommendation.

For more details, see Managing recommendations page.

Understand recommendations

Adaptive Logs must wait some time before it can collect enough query data to analyze and make recommendations. The default time period is 15 days. After Adaptive Logs has collected enough data to analyze, it evaluates the previous 15 days of query activity to make recommendations. After Adaptive Logs starts making recommendations, they are updated daily, and reflect any changes in your ingest and query behavior.

A recommendation includes the following information:

  • Query:Ingest - the ratio of log lines matching this pattern returned in all queries, to log lines ingested, over the previous 15 days. For example, if there are 100 lines matching a pattern, and each of these lines has been queried 5 times over the previous 15 days, the query to ingest ratio would be 5:1.
  • Volume - the volume of logs ingested for this pattern over the previous 15 days.
  • Current drop rate - the drop rate currently being applied to the recommendation. By default, this rate is 0.
  • Recommended drop rate - the drop rate the recommendation engine suggests applying to your logs.
  • Projected savings - projected savings over the following 15 day period with the recommended drop rate. This value is extrapolated from analyzing the previous 15 days if the Adaptive Logs recommendations been applied.
  • Pattern - the pattern being used to power the recommendation.

Adaptive Logs evaluates queries on a given data source regardless of where they originate. It ignores queries that are too broad or not typically used for observability needs. Recommendations for logs that can be dropped include logs that are not included in current query patterns. As query patterns change over time, recommendations are updated.

Understand patterns

A pattern is a representation of log lines that includes both fixed and variable content. Patterns are grouped by the parts of the logs that don’t change, that is, the fixed content.

Here’s an example of a pattern:

console
level=debug ts=<TIMESTAMP> caller=metrics.go:<NUM> traceID=<HEX> duration=<DURATION> <*>

Let’s look at each of the following pieces of this pattern.

  • level=debug: This is a constant string appearing in all log lines matching this pattern.

  • ts=<TIMESTAMP>: The ’ts=’ string is fixed, and the <TIMESTAMP> string is variable, but always a TIMESTAMP data type. Everything inside an angular bracket represents variable content. Possible types are:

    • <BYTESIZE>
    • <DURATION>
    • <HEX>
    • <IP>
    • <NUM>
    • <TIMESTAMP>
    • <UUID>
  • caller=metrics.go:<NUM>: This is a mix of fixed and variable content.

  • <*>: This represents variable alphanumeric string content.

A drop rate is the percentage of logs that you choose not to ingest into Grafana Cloud after they have been sent. An 80% drop rate means roughly 8 out of 10 log lines are not ingested. The drop rate is the mechanism that creates savings in your Cloud Logs spending.

Each log pattern has its own recommended drop rate based on its ingest volume and query behavior. You can manage each recommendation separately on the Adaptive Logs screen. The Recommended column shows the recommended percentage of log lines to drop. The Current(%) column shows the percentage of lines currently being dropped, or planned to be dropped if changes have not yet been applied.