shureban/laravel-prometheus

Laravel SDK for working with prometheus metrics

Installs: 2 017

Dependents: 0

Suggesters: 0

Security: 0

Stars: 2

Watchers: 1

Forks: 1

Open Issues: 0

Type:laravel-package

1.2.0 2022-11-09 12:26 UTC

This package is auto-updated.

Last update: 2025-03-09 17:36:00 UTC


README

Installation

Require this package with composer using the following command:

composer require shureban/laravel-prometheus

Add the following class to the providers array in config/app.php:

Shureban\LaravelPrometheus\PrometheusServiceProvider::class,

You can also publish the config file to change implementations (ie. interface to specific class).

php artisan vendor:publish --provider="Shureban\LaravelPrometheus\PrometheusServiceProvider"

Update .env config, change REDIS_CLIENT from redis to predis:

REDIS_CLIENT=predis

Creating metric class

CLI supporting

You may create metrics via CLI commands

# Creating counter metric CustomCounterMetricName
php artisan make:counter CustomCounterMetricName --name={name} --labels={label_1,label_2,label_N} --description={description} --dynamic

# Creating gauge metric CustomGaugeMetricName
php artisan make:gauge CustomGaugeMetricName --name={name} --labels={label_1,label_2,label_N} --description={description} --dynamic
Option Alias Required Description
name false Name of the metric
label false The metric labels list (comma separated)
description false The metric description
dynamic d false The metric description

Manual

Create folder, where you will contain your custom metrics classes (for example app/Prometheus). Realise constructor with metric static params.

namespace App\Prometheus;

use Shureban\LaravelPrometheus\Counter;
use Shureban\LaravelPrometheus\Attributes\Name;
use Shureban\LaravelPrometheus\Attributes\Labels;

class AuthCounter extends Counter
{
    public function __construct()
    {
        $name   = new Name('auth');
        $labels = new Labels(['event']);
        $help   = 'Counter of auth events';

        parent::__construct($name, $labels, $help);
    }
}

Usages

General metrics flow

Using DI (or not), increase the metric value.

use App\Prometheus\AuthCounter;

class RegisterController extends Controller
{
    public function __invoke(..., AuthCounter $counter): Response
    {
        // Registration new user logic
    
        $counter->withLabelsValues(['registration'])->inc();
    }
}

Or, if you have static list of events, you may realize following flow:

namespace App\Prometheus\Counters;

use Shureban\LaravelPrometheus\Counter;
use Shureban\LaravelPrometheus\Attributes\Name;
use Shureban\LaravelPrometheus\Attributes\Labels;

class AuthCounter extends Counter
{
    public function __construct()
    {
        //... 
    }
    
    public function registration(): void 
    {
        $this->withLabelsValues(['registration'])->inc();
    }
}

This way helps you encapsulate logic with labels, and the code seems pretty

use App\Prometheus\AuthCounter;

class RegisterController extends Controller
{
    public function __invoke(..., AuthCounter $counter): Response
    {
        // Registration new user logic
    
        $counter->registration();
    }
}

Dynamic metrics flow

Dynamic flow may help you attach more labels with different sizes

use App\Prometheus\AuthCounter;
use Shureban\LaravelPrometheus\Attributes\Labels;

class RegisterController extends Controller
{
    public function __invoke(..., DynamicAuthCounter $counter): Response
    {
        // Registration new user logic
    
        $counter->withLabels(Labels::newFromArray(['event' => 'registration', 'country' => 'US']))->inc();
        $counter->withLabels(Labels::newFromArray(['event' => 'registration', 'country' => 'US', 'browser' => 'chrome']))->inc();
        $counter->withLabels(Labels::newFromCollection($user->only(['country', 'browser'])))->inc();
    }
}

Rendering

Render metrics data in text format

Using config

In config/prometheus.php, find web_route param and set preferred route path. Default is /prometheus/metrics.

Manual

For render metrics by route, you need to provide next code:

$renderer = new RenderTextFormat();

return response($renderer->render(), Response::HTTP_OK, ['Content-Type' => RenderTextFormat::MIME_TYPE]);

of using string type hinting

return response(new RenderTextFormat(), Response::HTTP_OK, ['Content-Type' => RenderTextFormat::MIME_TYPE]);