Files
operationSystem-docker/grafana-docker/php-example/example.php
2024-08-22 14:05:05 +09:00

49 lines
1.2 KiB
PHP

<?php
declare(strict_types=1);
require __DIR__ . '/vendor/autoload.php';
$statsd = new League\StatsD\Client();
$statsd->configure([
'host' => '127.0.0.1',
'port' => 8125,
'namespace' => 'performance'
]);
$ops = 0;
$requestsSent = 0;
$startTime = microtime(true);
pcntl_async_signals(true);
pcntl_signal(SIGINT, static function () use (&$ops, $startTime, &$requestsSent) {
$runtime = microtime(true) - $startTime;
$opsPerSecond = $ops / $runtime;
$requestsPerSecond = $requestsSent / $runtime;
echo PHP_EOL;
echo "Runtime:\t${runtime} Seconds\n";
echo "Ops:\t\t${ops} \n";
echo "Ops/s:\t\t${opsPerSecond} \n";
echo "Requests Sent:\t${requestsSent} \n";
echo "Requests/s:\t${requestsPerSecond} \n";
echo "Killed by Ctrl+C\n";
exit(0);
});
echo "Sending Random metrics. Use Ctrl+C to stop.\n";
while (true) {
$time = random_int(100, 400);
$types = ['search', 'book', 'login', 'login'];
$type = $types[random_int(0 , 3)];
$delta = random_int(1, 5);
$statsd->increment('request.successful.count,type=' . $type, $delta);
$statsd->timing('request.successful.time,type=' . $type, $time);
$requestsSent += $delta;
++$ops;
usleep(random_int(5, 55) * 1000);
echo '.';
}