Application metrics for PHP microservices. Counter, gauge, histogram, and timer types with zero instrumentation overhead. Prometheus-compatible export.
Part of the KislayPHP ecosystem.
kislayphp/metrics provides C++-backed metrics primitives for PHP applications. All metric operations use atomic operations — measuring your code doesn't slow it down.
<?php
$metrics = new Kislay\Metrics\Collector();
$metrics->counter('requests_total')->increment();
$metrics->histogram('request_duration_ms')->observe($ms);
echo $metrics->export(); // Prometheus text formatpie install kislayphp/metricsEnable in php.ini:
extension=kislayphp_metrics.so<?php
$metrics = new Kislay\Metrics\Collector();
// Counter — monotonically increasing
$metrics->counter('http_requests_total', ['method' => 'GET', 'status' => '200'])
->increment();
// Gauge — value that goes up and down
$metrics->gauge('active_connections')->set(42);
$metrics->gauge('queue_depth')->increment();
$metrics->gauge('queue_depth')->decrement();
// Histogram — distribution of values
$start = microtime(true);
// ... handle request ...
$metrics->histogram('request_duration_seconds')
->observe(microtime(true) - $start);
// Timer (convenience wrapper for histogram)
$timer = $metrics->timer('db_query_seconds')->start();
// ... run query ...
$timer->stop();
// Export as Prometheus text format
$app->get('/metrics', function($req, $res) use ($metrics) {
$res->send($metrics->export(), 'text/plain; version=0.0.4');
});namespace Kislay\Metrics;
class Collector {
public function counter(string $name, array $labels = []): Counter;
public function gauge(string $name, array $labels = []): Gauge;
public function histogram(string $name, array $labels = [], array $buckets = []): Histogram;
public function timer(string $name, array $labels = []): Timer;
public function export(): string; // Prometheus text format
public function reset(): void;
}
class Counter { public function increment(float $by = 1): void; public function get(): float; }
class Gauge { public function set(float $value): void; public function increment(float $by = 1): void; public function decrement(float $by = 1): void; public function get(): float; }
class Histogram { public function observe(float $value): void; }
class Timer { public function start(): TimerHandle; }
class TimerHandle { public function stop(): float; }Legacy aliases: KislayPHP\Metrics\*