Skip to content
play

GitHub Action

Pyrra Generate action

v1 Latest version

Pyrra Generate action

play

Pyrra Generate action

Generate Prometheus rule files from Pyrra SLO definitions

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Pyrra Generate action

uses: ArthurSens/pyrra-generate-action@v1

Learn more about this action in ArthurSens/pyrra-generate-action

Choose a version

pyrra-generate-action

Pyrra was created to make SLOs with Prometheus manageable, accessible, and easy to use for everyone!

The original design expected that we'd have access to the server where Prometheus recording rules are managed or to the kubernetes cluster where the Prometheus-operator is deployed to, but that is not always true.

With that in mind, pyrra recently got a new command generate which allow us to use Pyrra as a CLI tool to read SLO definitions and create rule files that follows the Prometheus rules format. The generated files can then be used for different use cases, e.g. upload rules to a managed Prometheus service like Grafana Cloud or AWS Managed Prometheus.

📚 Usage

Workflow

Create a .yml file in your .github/workflows folder (you can find more info about the structure in the GitHub Docs):

.github/workflows/example.yml

on:
  push:
    branches:
      - main

jobs:
  generate_rules:
    runs-on: ubuntu-latest
    name: Generate Rules from SLOs
    steps:
      - uses: actions/checkout@v3
      - name: Generate rule files
        id: generate
        uses: ArthurSens/pyrra-generate-action@v1
        with:
          configFiles: "examples/*.yaml"
          outputFolder: "/tmp/output/"
          genericRules: true
      - name: Upload to mimir
        uses: ArthurSens/mimirtool-rules-load-action@v1
        with:
          address: ${{ secrets.MIMIR_ADDRESS }}
          id: ${{ secrets.MIMIR_TENANT_ID }}
          key: ${{ secrets.MIMIR_API_KEY }}
          user: ${{ secrets.MIMIR_USER }}
          ruleFilesPath: /tmp/output/*.yaml

⚙️ Action Inputs

Here are all the inputs pyrra-generate-action takes:

Key Value Required Default
configFiles Path to SLO manifests Yes ./*.yaml
outputFolder Path where rule files will be generated No ./output
genericRules Enables generic recording rules generation to make it easier for tools like Grafana. Remember that generic rules arent supported for SLOs with "grouping" No false