-
Notifications
You must be signed in to change notification settings - Fork 192
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Add metrics implementation * Apply cs-fixer * Downgrade to php 7.4 * [TODO] Suppress phan for now * Add basic example * [TODO] Remove outdated prometheus example for now * Add otlp metric converter * Add metric stream tests * Downgrade to php 7.4 - fix asynchronous counter instrument type * Add missing psalm-suppress annotations * Add `ext-gmp` to composer suggest * Fix `Sdk` -> `SDK` * Remove `_bridge.php` * Add array typehints * Add `Interface` suffix to interfaces * Add aggregation / attribute processor / staleness handler tests * Apply rector * Simplify filtered attribute processor * Move instrument deduplication to meter Allows removing view registry dependency from `MetricFactory`. Should ideally turn of staleness handling for asynchronous instruments with permanently registered callbacks (drop all `::onStale()` callbacks and prevent addition of new callbacks). * Allow injecting metric factory * Release `::onStale()` callbacks if permanent observer callback registered * Add `MultiObserver` tests * Add php-doc for exporter temporality * Resolve phan issues * Add note about forward compatibility * Add exemplar tests * Remove special handling for callbacks being registered multiple times Was mainly a side-effect of using `spl_object_id()`; lead to inconsistent behavior between providing same and identical callbacks; reverting back to incrementing index, keyspace is large enough. * Add basic `Meter` / `MeterProvider` tests * Add view `SelectionCriteria` tests * Allow `MetricReader`s to configure default aggregation - move default aggregation handling to metric reader / metric exporter - move view registration to meter provider constructor - move exemplar reservoir creation to aggregation to support user implementations - remove `AttributeProcessor` from view as baggage access was dropped from spec - deduplicate metric streams * Add support for weakening `$this` reference of asynchronous callbacks * Minor improvements - add missing `Interface` suffix - move callback destructors to metric observer to not detach if meter and meter provider are out of scope - simplify `::viewRegistrationRequests()` by readding fallback view * Add OTLP metric exporter * Log export failure * Minor improvements - rename `MetricObserver::weakMap()` to `::destructors()` to better reflect usage` - move `ReferenceCounter::acquire()` call to corresponding `MetricObserver::observe()` call for consistency - cache instrumentation scope id in `Meter` to avoid repeated calls to `serialize()` - remove obsolete instrument type check from `ViewProjection`, leftover from supporting aggregation per type * Suppress `PhanAccessMethodInternal` due to being too strict for our usecase * Add workaround for observer segfault if destruct is initiated by `WeakMap` key going out of scope * Mark internal classes as internal * Add in-memory and stream exporter * Add metric converter test * Add metric observer tests * Add view registry tests * Add metric reader tests * Improve stream test coverage * Improve meter test coverage * Apply rector * Add delayed staleness handler
- Loading branch information
Showing
186 changed files
with
9,105 additions
and
1,596 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
<?php | ||
|
||
// Example based on https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/supplementary-guidelines.md#synchronous-example | ||
declare(strict_types=1); | ||
|
||
require_once __DIR__ . '/../../vendor/autoload.php'; | ||
|
||
use OpenTelemetry\Contrib\Otlp\StreamMetricExporter; | ||
use OpenTelemetry\SDK\Common\Attribute\Attributes; | ||
use OpenTelemetry\SDK\Common\Instrumentation\InstrumentationScopeFactory; | ||
use OpenTelemetry\SDK\Common\Time\ClockFactory; | ||
use OpenTelemetry\SDK\Metrics\Aggregation\ExplicitBucketHistogramAggregation; | ||
use OpenTelemetry\SDK\Metrics\Exemplar\ExemplarFilter\WithSampledTraceExemplarFilter; | ||
use OpenTelemetry\SDK\Metrics\MeterProvider; | ||
use OpenTelemetry\SDK\Metrics\MetricReader\ExportingReader; | ||
use OpenTelemetry\SDK\Metrics\StalenessHandler\ImmediateStalenessHandlerFactory; | ||
use OpenTelemetry\SDK\Metrics\View\CriteriaViewRegistry; | ||
use OpenTelemetry\SDK\Metrics\View\SelectionCriteria\InstrumentNameCriteria; | ||
use OpenTelemetry\SDK\Metrics\View\ViewTemplate; | ||
use OpenTelemetry\SDK\Resource\ResourceInfoFactory; | ||
|
||
$clock = ClockFactory::getDefault(); | ||
$reader = new ExportingReader(new StreamMetricExporter(STDOUT, /*Temporality::CUMULATIVE*/), $clock); | ||
|
||
// Let's imagine we export the metrics as Histogram, and to simplify the story we will only have one histogram bucket (-Inf, +Inf): | ||
$views = new CriteriaViewRegistry(); | ||
$views->register( | ||
new InstrumentNameCriteria('http.server.duration'), | ||
ViewTemplate::create() | ||
->withAttributeKeys(['http.method', 'http.status_code']) | ||
->withAggregation(new ExplicitBucketHistogramAggregation([])), | ||
); | ||
|
||
$meterProvider = new MeterProvider( | ||
null, | ||
ResourceInfoFactory::emptyResource(), | ||
$clock, | ||
Attributes::factory(), | ||
new InstrumentationScopeFactory(Attributes::factory()), | ||
[$reader], | ||
$views, | ||
new WithSampledTraceExemplarFilter(), | ||
new ImmediateStalenessHandlerFactory(), | ||
); | ||
|
||
$serverDuration = $meterProvider->getMeter('io.opentelemetry.contrib.php')->createHistogram( | ||
'http.server.duration', | ||
'ms', | ||
'measures the duration inbound HTTP requests', | ||
); | ||
|
||
// During the time range (T0, T1]: | ||
$serverDuration->record(50, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(100, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(1, ['http.method' => 'GET', 'http.status_code' => 500]); | ||
$reader->collect(); | ||
|
||
// During the time range (T1, T2]: | ||
$reader->collect(); | ||
|
||
// During the time range (T2, T3]: | ||
$serverDuration->record(5, ['http.method' => 'GET', 'http.status_code' => 500]); | ||
$serverDuration->record(2, ['http.method' => 'GET', 'http.status_code' => 500]); | ||
$reader->collect(); | ||
|
||
// During the time range (T3, T4]: | ||
$serverDuration->record(100, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$reader->collect(); | ||
|
||
// During the time range (T4, T5]: | ||
$serverDuration->record(100, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(30, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(50, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$reader->collect(); | ||
|
||
$meterProvider->shutdown(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
<?php | ||
|
||
declare(strict_types=1); | ||
|
||
require __DIR__ . '/../../../../vendor/autoload.php'; | ||
|
||
use GuzzleHttp\Client; | ||
use GuzzleHttp\Psr7\HttpFactory; | ||
use OpenTelemetry\API\Metrics\ObserverInterface; | ||
use OpenTelemetry\Contrib\OtlpHttp\MetricExporter; | ||
use OpenTelemetry\SDK\Common\Attribute\Attributes; | ||
use OpenTelemetry\SDK\Common\Instrumentation\InstrumentationScopeFactory; | ||
use OpenTelemetry\SDK\Common\Time\ClockFactory; | ||
use OpenTelemetry\SDK\Metrics\Exemplar\ExemplarFilter\WithSampledTraceExemplarFilter; | ||
use OpenTelemetry\SDK\Metrics\MeterProvider; | ||
use OpenTelemetry\SDK\Metrics\MetricReader\ExportingReader; | ||
use OpenTelemetry\SDK\Metrics\StalenessHandler\ImmediateStalenessHandlerFactory; | ||
use OpenTelemetry\SDK\Metrics\View\CriteriaViewRegistry; | ||
use OpenTelemetry\SDK\Resource\ResourceInfoFactory; | ||
|
||
$clock = ClockFactory::getDefault(); | ||
$reader = new ExportingReader(MetricExporter::create( | ||
new Client(), | ||
new HttpFactory(), | ||
new HttpFactory(), | ||
'http://collector:4318/v1/metrics', | ||
), $clock); | ||
|
||
$meterProvider = new MeterProvider( | ||
null, | ||
ResourceInfoFactory::defaultResource(), | ||
$clock, | ||
Attributes::factory(), | ||
new InstrumentationScopeFactory(Attributes::factory()), | ||
[$reader], | ||
new CriteriaViewRegistry(), | ||
new WithSampledTraceExemplarFilter(), | ||
new ImmediateStalenessHandlerFactory(), | ||
); | ||
|
||
$meter = $meterProvider->getMeter('io.opentelemetry.contrib.php'); | ||
$meter | ||
->createObservableUpDownCounter('process.memory.usage', 'By', 'The amount of physical memory in use.') | ||
->observe(static function (ObserverInterface $observer): void { | ||
$observer->observe(memory_get_usage(true)); | ||
}); | ||
|
||
$serverDuration = $meter | ||
->createHistogram('http.server.duration', 'ms', 'measures the duration inbound HTTP requests'); | ||
|
||
// During the time range (T0, T1]: | ||
$serverDuration->record(50, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(100, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(1, ['http.method' => 'GET', 'http.status_code' => 500]); | ||
$reader->collect(); | ||
|
||
// During the time range (T1, T2]: | ||
$reader->collect(); | ||
|
||
// During the time range (T2, T3]: | ||
$serverDuration->record(5, ['http.method' => 'GET', 'http.status_code' => 500]); | ||
$serverDuration->record(2, ['http.method' => 'GET', 'http.status_code' => 500]); | ||
$reader->collect(); | ||
|
||
// During the time range (T3, T4]: | ||
$serverDuration->record(100, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$reader->collect(); | ||
|
||
// During the time range (T4, T5]: | ||
$serverDuration->record(100, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(30, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$serverDuration->record(50, ['http.method' => 'GET', 'http.status_code' => 200]); | ||
$reader->collect(); | ||
|
||
$meterProvider->shutdown(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
<?php | ||
|
||
declare(strict_types=1); | ||
|
||
namespace OpenTelemetry\API\Metrics; | ||
|
||
use OpenTelemetry\Context\Context; | ||
|
||
interface HistogramInterface | ||
{ | ||
|
||
/** | ||
* @param float|int $amount non-negative amount to record | ||
* @param iterable<non-empty-string, string|bool|float|int|array|null> $attributes | ||
* attributes of the data point | ||
* @param Context|false|null $context execution context | ||
* | ||
* @see https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/metrics/api.md#record | ||
*/ | ||
public function record($amount, iterable $attributes = [], $context = null): void; | ||
} |
This file was deleted.
Oops, something went wrong.
Oops, something went wrong.