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
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 |
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);
}
}
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 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();
}
}
Render metrics data in text format
In config/prometheus.php
, find web_route
param and set preferred route path. Default is /prometheus/metrics
.
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]);