-
Notifications
You must be signed in to change notification settings - Fork 101
/
Copy pathSummary.php
124 lines (107 loc) · 3.32 KB
/
Summary.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
declare(strict_types=1);
namespace Prometheus;
use InvalidArgumentException;
use Prometheus\Storage\Adapter;
class Summary extends Collector
{
const RESERVED_LABELS = ['quantile'];
const TYPE = 'summary';
/**
* @var float[]|null
*/
private $quantiles;
/**
* @var int
*/
private $maxAgeSeconds;
/**
* @param Adapter $adapter
* @param string $namespace
* @param string $name
* @param string $help
* @param string[] $labels
* @param int $maxAgeSeconds
* @param float[] $quantiles
*/
public function __construct(
Adapter $adapter,
string $namespace,
string $name,
string $help,
array $labels = [],
int $maxAgeSeconds = 600,
array $quantiles = null
) {
parent::__construct($adapter, $namespace, $name, $help, $labels);
if (null === $quantiles) {
$quantiles = self::getDefaultQuantiles();
}
if (0 === count($quantiles)) {
throw new InvalidArgumentException("Summary must have at least one quantile.");
}
for ($i = 0; $i < count($quantiles) - 1; $i++) {
if ($quantiles[$i] >= $quantiles[$i + 1]) {
throw new InvalidArgumentException(
"Summary quantiles must be in increasing order: " .
$quantiles[$i] . " >= " . $quantiles[$i + 1]
);
}
}
foreach ($quantiles as $quantile) {
if ($quantile <= 0 || $quantile >= 1) {
throw new InvalidArgumentException("Quantile $quantile invalid: Expected number between 0 and 1.");
}
}
if ($maxAgeSeconds <= 0) {
throw new InvalidArgumentException("maxAgeSeconds $maxAgeSeconds invalid: Expected number greater than 0.");
}
if (count(array_intersect(self::RESERVED_LABELS, $labels)) > 0) {
throw new InvalidArgumentException("Summary cannot have a label named " . implode(', ', self::RESERVED_LABELS) . ".");
}
$this->quantiles = $quantiles;
$this->maxAgeSeconds = $maxAgeSeconds;
}
/**
* List of default quantiles suitable for typical web application latency metrics
*
* @return float[]
*/
public static function getDefaultQuantiles(): array
{
return [
0.01,
0.05,
0.5,
0.95,
0.99,
];
}
/**
* @param double $value e.g. 123
* @param string[] $labels e.g. ['status', 'opcode']
*/
public function observe(float $value, array $labels = []): void
{
$this->assertLabelsAreDefinedCorrectly($labels);
$this->storageAdapter->updateSummary(
[
'value' => $value,
'name' => $this->getName(),
'help' => $this->getHelp(),
'type' => $this->getType(),
'labelNames' => $this->getLabelNames(),
'labelValues' => $labels,
'maxAgeSeconds' => $this->maxAgeSeconds,
'quantiles' => $this->quantiles,
]
);
}
/**
* @return string
*/
public function getType(): string
{
return self::TYPE;
}
}