Hello Folks!

You must be trying out Prometheus in your infrastructure. While doing so, you have encountered some rules in Prometheus. Those are called recording rules and alerting rules.

Here in this article, we are going to talk about the recording rules.

What are Recording Rules?

Recording rules are those rules that allow to run PromQL expressions that otherwise take longer to compute time series data or expressions that are very frequently needed.

For example, node exporter collects metrics about memory. It measures how much is the total memory allocated to a system. How much memory is currently available. Now, if we want to get a percentage of memory that is free, we can write a PromQL expression like below:

(node_memory_MemAvailable_bytes /  node_memory_MemTotal_bytes) * 100

But as the metrics storage gets heavy more and more, the above computation will take some time for all the instances in the infrastructure. Therefore, a recording rule can be written to compute another set of metrics consisting of free memory percentage as the value.

Let’s define the recording rule.

Defining Recording Rule

  1. Edit main prometheues config to include a rules configuration file.
$ vim prometheus.yml

  - "prometheus_recording_rules.yml"
  1. Write the recording rule in “prometheus_recording_rules.yml” config file
$ cat prometheus_recording_rules.yml 

  - name: memory_percent
      - record: instance:memory_free:percent
        expr: (node_memory_MemAvailable_bytes /  node_memory_MemTotal_bytes) * 100
  1. Now, visualize the new data set.
Showing Free Memory Percentage using Prometheus Recording Rules

Decoding Recording Rule Definition

  - name: memory_percent
      - record: instance:memory_free:percent
        expr: (node_memory_MemAvailable_bytes /  node_memory_MemTotal_bytes) * 100
  • Rules are defined within a group called as a rule group.
  • memory_percent is name of the group. You can name it anything as you like :).
  • Then, multiple rules can be defined within a group. We have defined a single rule.
  • record is name of the new time series data.
  • expr is the PromQL expression that gets evaluated at regular intervals


Hey Friends, Thank you for visiting my blog and spending some time reading it. Myself Aryan who works in computer technologies and keeps on pen down my understanding of various topics. This blog is a write-up of my understanding of various technologies after reading different materials about it. I hope that it helps you in some way.


Leave a Reply

Your email address will not be published. Required fields are marked *