-
Notifications
You must be signed in to change notification settings - Fork 162
/
Copy pathSamplingRuleMatchingBench.php
117 lines (104 loc) · 3.08 KB
/
SamplingRuleMatchingBench.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
<?php
declare(strict_types=1);
namespace Benchmarks\API;
class SamplingRuleMatchingBench
{
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchGlobMatching1(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver.non-matching", "web.request", "/bar", "glob");
}
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchGlobMatching2(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver", "web.request.non-matching", "/bar", "glob");
}
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchGlobMatching3(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver", "web.request", "/bar.non-matching", "glob");
}
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchGlobMatching4(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver", "web.request", "/b?r", "glob");
}
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchRegexMatching1(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver\.non-matching", "web\.request", "\/bar", "regex");
}
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchRegexMatching2(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver", "web\.request\.non-matching", "\/bar", "regex");
}
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchRegexMatching3(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver", "web\.request", "\/bar\.non-matching", "regex");
}
/**
* @Revs(1000)
* @Iterations(10)
* @OutputTimeUnit("microseconds")
* @RetryThreshold(10.0)
* @Warmup(1)
*/
public function benchRegexMatching4(): void
{
$this->runSamplingRuleMatchingBenchmark("webserver", "web\.request", "\/b\?r", "regex");
}
public function runSamplingRuleMatchingBenchmark($servicePattern, $namePattern, $resourcePattern, $format): void
{
ini_set("datadog.trace.sampling_rules_format", $format);
ini_set("datadog.trace.sampling_rules", '[{"name":"' . $namePattern . '","service":"' . $servicePattern . '","resource":"' . $resourcePattern . '","sample_rate":0.7},{"sample_rate": 0.3}]');
$root = \DDTrace\root_span();
$root->service = "webserver";
$root->name = "web.request";
$root->resource = "/bar";
\DDTrace\get_priority_sampling();
}
}