Search in sources :

Example 1 with SdkMeterProvider

use of io.opentelemetry.sdk.metrics.SdkMeterProvider in project opentelemetry-java by open-telemetry.

the class OpenTelemetrySdkBuilder method build.

/**
 * Returns a new {@link OpenTelemetrySdk} built with the configuration of this {@link
 * OpenTelemetrySdkBuilder}. This SDK is not registered as the global {@link
 * io.opentelemetry.api.OpenTelemetry}. It is recommended that you register one SDK using {@link
 * OpenTelemetrySdkBuilder#buildAndRegisterGlobal()} for use by instrumentation that requires
 * access to a global instance of {@link io.opentelemetry.api.OpenTelemetry}.
 *
 * @see GlobalOpenTelemetry
 */
public OpenTelemetrySdk build() {
    SdkTracerProvider tracerProvider = this.tracerProvider;
    if (tracerProvider == null) {
        tracerProvider = SdkTracerProvider.builder().build();
    }
    SdkMeterProvider meterProvider = this.meterProvider;
    if (meterProvider == null) {
        meterProvider = SdkMeterProvider.builder().build();
    }
    SdkLogEmitterProvider logEmitterProvider = this.logEmitterProvider;
    if (logEmitterProvider == null) {
        logEmitterProvider = SdkLogEmitterProvider.builder().build();
    }
    return new OpenTelemetrySdk(tracerProvider, meterProvider, logEmitterProvider, propagators);
}
Also used : SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) SdkLogEmitterProvider(io.opentelemetry.sdk.logs.SdkLogEmitterProvider) SdkTracerProvider(io.opentelemetry.sdk.trace.SdkTracerProvider)

Example 2 with SdkMeterProvider

use of io.opentelemetry.sdk.metrics.SdkMeterProvider in project opentelemetry-java by open-telemetry.

the class OtlpExporterIntegrationTest method testMetricExport.

private static void testMetricExport(MetricExporter metricExporter) {
    MetricReaderFactory reader = PeriodicMetricReader.builder(metricExporter).setInterval(Duration.ofSeconds(5)).newMetricReaderFactory();
    SdkMeterProvider meterProvider = SdkMeterProvider.builder().setResource(RESOURCE).registerMetricReader(reader).build();
    Meter meter = meterProvider.meterBuilder(OtlpExporterIntegrationTest.class.getName()).build();
    LongCounter longCounter = meter.counterBuilder("my-counter").build();
    longCounter.add(100, Attributes.builder().put("key", "value").build());
    try {
        await().atMost(Duration.ofSeconds(30)).untilAsserted(() -> assertThat(grpcServer.metricRequests).hasSize(1));
    } finally {
        meterProvider.close();
    }
    ExportMetricsServiceRequest request = grpcServer.metricRequests.get(0);
    assertThat(request.getResourceMetricsCount()).isEqualTo(1);
    ResourceMetrics resourceMetrics = request.getResourceMetrics(0);
    assertThat(resourceMetrics.getResource().getAttributesList()).contains(KeyValue.newBuilder().setKey(ResourceAttributes.SERVICE_NAME.getKey()).setValue(AnyValue.newBuilder().setStringValue("integration test").build()).build());
    assertThat(resourceMetrics.getInstrumentationLibraryMetricsCount()).isEqualTo(1);
    InstrumentationLibraryMetrics ilMetrics = resourceMetrics.getInstrumentationLibraryMetrics(0);
    assertThat(ilMetrics.getInstrumentationLibrary().getName()).isEqualTo(OtlpExporterIntegrationTest.class.getName());
    assertThat(ilMetrics.getMetricsCount()).isEqualTo(1);
    Metric metric = ilMetrics.getMetrics(0);
    assertThat(metric.getName()).isEqualTo("my-counter");
    assertThat(metric.getDataCase()).isEqualTo(Metric.DataCase.SUM);
    Sum sum = metric.getSum();
    assertThat(sum.getAggregationTemporality()).isEqualTo(AggregationTemporality.AGGREGATION_TEMPORALITY_CUMULATIVE);
    assertThat(sum.getDataPointsCount()).isEqualTo(1);
    NumberDataPoint dataPoint = sum.getDataPoints(0);
    assertThat(dataPoint.getAsInt()).isEqualTo(100);
    assertThat(dataPoint.getAttributesList()).isEqualTo(Collections.singletonList(KeyValue.newBuilder().setKey("key").setValue(AnyValue.newBuilder().setStringValue("value").build()).build()));
}
Also used : ResourceMetrics(io.opentelemetry.proto.metrics.v1.ResourceMetrics) SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) Meter(io.opentelemetry.api.metrics.Meter) NumberDataPoint(io.opentelemetry.proto.metrics.v1.NumberDataPoint) MetricReaderFactory(io.opentelemetry.sdk.metrics.export.MetricReaderFactory) Metric(io.opentelemetry.proto.metrics.v1.Metric) Sum(io.opentelemetry.proto.metrics.v1.Sum) InstrumentationLibraryMetrics(io.opentelemetry.proto.metrics.v1.InstrumentationLibraryMetrics) LongCounter(io.opentelemetry.api.metrics.LongCounter) ExportMetricsServiceRequest(io.opentelemetry.proto.collector.metrics.v1.ExportMetricsServiceRequest)

Example 3 with SdkMeterProvider

use of io.opentelemetry.sdk.metrics.SdkMeterProvider in project opentelemetry-java-instrumentation by open-telemetry.

the class HttpClientMetricsTest method collectsMetrics.

@Test
void collectsMetrics() {
    InMemoryMetricReader metricReader = InMemoryMetricReader.create();
    SdkMeterProvider meterProvider = SdkMeterProvider.builder().registerMetricReader(metricReader).setMinimumCollectionInterval(Duration.ZERO).build();
    RequestListener listener = HttpClientMetrics.get().create(meterProvider.get("test"));
    Attributes requestAttributes = Attributes.builder().put("http.method", "GET").put("http.url", "https://localhost:1234/").put("http.host", "host").put("http.target", "/").put("http.scheme", "https").put("net.peer.name", "localhost").put("net.peer.ip", "0.0.0.0").put("net.peer.port", 1234).build();
    Attributes responseAttributes = Attributes.builder().put("http.flavor", "2.0").put("http.server_name", "server").put("http.status_code", 200).build();
    Context parent = Context.root().with(Span.wrap(SpanContext.create("ff01020304050600ff0a0b0c0d0e0f00", "090a0b0c0d0e0f00", TraceFlags.getSampled(), TraceState.getDefault())));
    Context context1 = listener.start(parent, requestAttributes, nanos(100));
    assertThat(metricReader.collectAllMetrics()).isEmpty();
    Context context2 = listener.start(Context.root(), requestAttributes, nanos(150));
    assertThat(metricReader.collectAllMetrics()).isEmpty();
    listener.end(context1, responseAttributes, nanos(250));
    assertThat(metricReader.collectAllMetrics()).hasSize(1).anySatisfy(metric -> assertThat(metric).hasName("http.client.duration").hasUnit("ms").hasDoubleHistogram().points().satisfiesExactly(point -> {
        assertThat(point).hasSum(150).attributes().containsOnly(attributeEntry("net.peer.name", "localhost"), attributeEntry("net.peer.port", 1234), attributeEntry("http.method", "GET"), attributeEntry("http.flavor", "2.0"), attributeEntry("http.status_code", 200));
        assertThat(point).exemplars().hasSize(1);
        assertThat(point.getExemplars().get(0)).hasTraceId("ff01020304050600ff0a0b0c0d0e0f00").hasSpanId("090a0b0c0d0e0f00");
    }));
    listener.end(context2, responseAttributes, nanos(300));
    assertThat(metricReader.collectAllMetrics()).hasSize(1).anySatisfy(metric -> assertThat(metric).hasName("http.client.duration").hasDoubleHistogram().points().satisfiesExactly(point -> assertThat(point).hasSum(300)));
}
Also used : Context(io.opentelemetry.context.Context) SpanContext(io.opentelemetry.api.trace.SpanContext) OpenTelemetryAssertions.attributeEntry(io.opentelemetry.sdk.testing.assertj.OpenTelemetryAssertions.attributeEntry) TraceFlags(io.opentelemetry.api.trace.TraceFlags) Context(io.opentelemetry.context.Context) Span(io.opentelemetry.api.trace.Span) SpanContext(io.opentelemetry.api.trace.SpanContext) Attributes(io.opentelemetry.api.common.Attributes) TimeUnit(java.util.concurrent.TimeUnit) Test(org.junit.jupiter.api.Test) RequestListener(io.opentelemetry.instrumentation.api.instrumenter.RequestListener) SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) TraceState(io.opentelemetry.api.trace.TraceState) InMemoryMetricReader(io.opentelemetry.sdk.testing.exporter.InMemoryMetricReader) Duration(java.time.Duration) MetricAssertions.assertThat(io.opentelemetry.sdk.testing.assertj.MetricAssertions.assertThat) InMemoryMetricReader(io.opentelemetry.sdk.testing.exporter.InMemoryMetricReader) RequestListener(io.opentelemetry.instrumentation.api.instrumenter.RequestListener) SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) Attributes(io.opentelemetry.api.common.Attributes) Test(org.junit.jupiter.api.Test)

Example 4 with SdkMeterProvider

use of io.opentelemetry.sdk.metrics.SdkMeterProvider in project opentelemetry-java-instrumentation by open-telemetry.

the class RpcClientMetricsTest method collectsMetrics.

@Test
void collectsMetrics() {
    InMemoryMetricReader metricReader = InMemoryMetricReader.createDelta();
    SdkMeterProvider meterProvider = SdkMeterProvider.builder().registerMetricReader(metricReader).setMinimumCollectionInterval(Duration.ZERO).build();
    RequestListener listener = RpcClientMetrics.get().create(meterProvider.get("test"));
    Attributes requestAttributes = Attributes.builder().put(SemanticAttributes.RPC_SYSTEM, "grpc").put(SemanticAttributes.RPC_SERVICE, "myservice.EchoService").put(SemanticAttributes.RPC_METHOD, "exampleMethod").build();
    Attributes responseAttributes1 = Attributes.builder().put(SemanticAttributes.NET_PEER_NAME, "example.com").put(SemanticAttributes.NET_PEER_IP, "127.0.0.1").put(SemanticAttributes.NET_PEER_PORT, 8080).put(SemanticAttributes.NET_TRANSPORT, "ip_tcp").build();
    Attributes responseAttributes2 = Attributes.builder().put(SemanticAttributes.NET_PEER_IP, "127.0.0.1").put(SemanticAttributes.NET_PEER_PORT, 8080).put(SemanticAttributes.NET_TRANSPORT, "ip_tcp").build();
    Context parent = Context.root().with(Span.wrap(SpanContext.create("ff01020304050600ff0a0b0c0d0e0f00", "090a0b0c0d0e0f00", TraceFlags.getSampled(), TraceState.getDefault())));
    Context context1 = listener.start(parent, requestAttributes, nanos(100));
    assertThat(metricReader.collectAllMetrics()).isEmpty();
    Context context2 = listener.start(Context.root(), requestAttributes, nanos(150));
    assertThat(metricReader.collectAllMetrics()).isEmpty();
    listener.end(context1, responseAttributes1, nanos(250));
    assertThat(metricReader.collectAllMetrics()).hasSize(1).anySatisfy(metric -> assertThat(metric).hasName("rpc.client.duration").hasUnit("ms").hasDoubleHistogram().points().satisfiesExactly(point -> {
        assertThat(point).hasSum(150).attributes().containsOnly(attributeEntry("rpc.system", "grpc"), attributeEntry("rpc.service", "myservice.EchoService"), attributeEntry("rpc.method", "exampleMethod"), attributeEntry("net.peer.name", "example.com"), attributeEntry("net.peer.port", 8080), attributeEntry("net.transport", "ip_tcp"));
        assertThat(point).exemplars().hasSize(1);
        assertThat(point.getExemplars().get(0)).hasTraceId("ff01020304050600ff0a0b0c0d0e0f00").hasSpanId("090a0b0c0d0e0f00");
    }));
    listener.end(context2, responseAttributes2, nanos(300));
    assertThat(metricReader.collectAllMetrics()).hasSize(1).anySatisfy(metric -> assertThat(metric).hasName("rpc.client.duration").hasUnit("ms").hasDoubleHistogram().points().satisfiesExactly(point -> {
        assertThat(point).hasSum(150).attributes().containsOnly(attributeEntry("rpc.system", "grpc"), attributeEntry("rpc.service", "myservice.EchoService"), attributeEntry("rpc.method", "exampleMethod"), attributeEntry("net.peer.ip", "127.0.0.1"), attributeEntry("net.peer.port", 8080), attributeEntry("net.transport", "ip_tcp"));
    }));
}
Also used : Context(io.opentelemetry.context.Context) SpanContext(io.opentelemetry.api.trace.SpanContext) OpenTelemetryAssertions.attributeEntry(io.opentelemetry.sdk.testing.assertj.OpenTelemetryAssertions.attributeEntry) TraceFlags(io.opentelemetry.api.trace.TraceFlags) Context(io.opentelemetry.context.Context) Span(io.opentelemetry.api.trace.Span) SpanContext(io.opentelemetry.api.trace.SpanContext) SemanticAttributes(io.opentelemetry.semconv.trace.attributes.SemanticAttributes) Attributes(io.opentelemetry.api.common.Attributes) TimeUnit(java.util.concurrent.TimeUnit) Test(org.junit.jupiter.api.Test) RequestListener(io.opentelemetry.instrumentation.api.instrumenter.RequestListener) SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) TraceState(io.opentelemetry.api.trace.TraceState) InMemoryMetricReader(io.opentelemetry.sdk.testing.exporter.InMemoryMetricReader) Duration(java.time.Duration) MetricAssertions.assertThat(io.opentelemetry.sdk.testing.assertj.MetricAssertions.assertThat) InMemoryMetricReader(io.opentelemetry.sdk.testing.exporter.InMemoryMetricReader) RequestListener(io.opentelemetry.instrumentation.api.instrumenter.RequestListener) SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) SemanticAttributes(io.opentelemetry.semconv.trace.attributes.SemanticAttributes) Attributes(io.opentelemetry.api.common.Attributes) Test(org.junit.jupiter.api.Test)

Example 5 with SdkMeterProvider

use of io.opentelemetry.sdk.metrics.SdkMeterProvider in project opentelemetry-java-instrumentation by open-telemetry.

the class RpcServerMetricsTest method collectsMetrics.

@Test
void collectsMetrics() {
    InMemoryMetricReader metricReader = InMemoryMetricReader.createDelta();
    SdkMeterProvider meterProvider = SdkMeterProvider.builder().registerMetricReader(metricReader).setMinimumCollectionInterval(Duration.ZERO).build();
    RequestListener listener = RpcServerMetrics.get().create(meterProvider.get("test"));
    Attributes requestAttributes = Attributes.builder().put(SemanticAttributes.RPC_SYSTEM, "grpc").put(SemanticAttributes.RPC_SERVICE, "myservice.EchoService").put(SemanticAttributes.RPC_METHOD, "exampleMethod").build();
    Attributes responseAttributes1 = Attributes.builder().put(SemanticAttributes.NET_HOST_NAME, "example.com").put(SemanticAttributes.NET_HOST_IP, "127.0.0.1").put(SemanticAttributes.NET_HOST_PORT, 8080).put(SemanticAttributes.NET_TRANSPORT, "ip_tcp").build();
    Attributes responseAttributes2 = Attributes.builder().put(SemanticAttributes.NET_HOST_IP, "127.0.0.1").put(SemanticAttributes.NET_HOST_PORT, 8080).put(SemanticAttributes.NET_TRANSPORT, "ip_tcp").build();
    Context parent = Context.root().with(Span.wrap(SpanContext.create("ff01020304050600ff0a0b0c0d0e0f00", "090a0b0c0d0e0f00", TraceFlags.getSampled(), TraceState.getDefault())));
    Context context1 = listener.start(parent, requestAttributes, nanos(100));
    assertThat(metricReader.collectAllMetrics()).isEmpty();
    Context context2 = listener.start(Context.root(), requestAttributes, nanos(150));
    assertThat(metricReader.collectAllMetrics()).isEmpty();
    listener.end(context1, responseAttributes1, nanos(250));
    assertThat(metricReader.collectAllMetrics()).hasSize(1).anySatisfy(metric -> assertThat(metric).hasName("rpc.server.duration").hasUnit("ms").hasDoubleHistogram().points().satisfiesExactly(point -> {
        assertThat(point).hasSum(150).attributes().containsOnly(attributeEntry("rpc.system", "grpc"), attributeEntry("rpc.service", "myservice.EchoService"), attributeEntry("rpc.method", "exampleMethod"), attributeEntry("net.host.name", "example.com"), attributeEntry("net.transport", "ip_tcp"));
        assertThat(point).exemplars().hasSize(1);
        assertThat(point.getExemplars().get(0)).hasTraceId("ff01020304050600ff0a0b0c0d0e0f00").hasSpanId("090a0b0c0d0e0f00");
    }));
    listener.end(context2, responseAttributes2, nanos(300));
    assertThat(metricReader.collectAllMetrics()).hasSize(1).anySatisfy(metric -> assertThat(metric).hasName("rpc.server.duration").hasUnit("ms").hasDoubleHistogram().points().satisfiesExactly(point -> {
        assertThat(point).hasSum(150).attributes().containsOnly(attributeEntry("rpc.system", "grpc"), attributeEntry("rpc.service", "myservice.EchoService"), attributeEntry("rpc.method", "exampleMethod"), attributeEntry("net.host.ip", "127.0.0.1"), attributeEntry("net.transport", "ip_tcp"));
    }));
}
Also used : Context(io.opentelemetry.context.Context) SpanContext(io.opentelemetry.api.trace.SpanContext) OpenTelemetryAssertions.attributeEntry(io.opentelemetry.sdk.testing.assertj.OpenTelemetryAssertions.attributeEntry) TraceFlags(io.opentelemetry.api.trace.TraceFlags) Context(io.opentelemetry.context.Context) Span(io.opentelemetry.api.trace.Span) SpanContext(io.opentelemetry.api.trace.SpanContext) SemanticAttributes(io.opentelemetry.semconv.trace.attributes.SemanticAttributes) Attributes(io.opentelemetry.api.common.Attributes) TimeUnit(java.util.concurrent.TimeUnit) Test(org.junit.jupiter.api.Test) RequestListener(io.opentelemetry.instrumentation.api.instrumenter.RequestListener) SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) TraceState(io.opentelemetry.api.trace.TraceState) InMemoryMetricReader(io.opentelemetry.sdk.testing.exporter.InMemoryMetricReader) Duration(java.time.Duration) MetricAssertions.assertThat(io.opentelemetry.sdk.testing.assertj.MetricAssertions.assertThat) InMemoryMetricReader(io.opentelemetry.sdk.testing.exporter.InMemoryMetricReader) RequestListener(io.opentelemetry.instrumentation.api.instrumenter.RequestListener) SdkMeterProvider(io.opentelemetry.sdk.metrics.SdkMeterProvider) SemanticAttributes(io.opentelemetry.semconv.trace.attributes.SemanticAttributes) Attributes(io.opentelemetry.api.common.Attributes) Test(org.junit.jupiter.api.Test)

Aggregations

SdkMeterProvider (io.opentelemetry.sdk.metrics.SdkMeterProvider)12 Test (org.junit.jupiter.api.Test)8 Span (io.opentelemetry.api.trace.Span)6 Context (io.opentelemetry.context.Context)6 MetricAssertions.assertThat (io.opentelemetry.sdk.testing.assertj.MetricAssertions.assertThat)6 InMemoryMetricReader (io.opentelemetry.sdk.testing.exporter.InMemoryMetricReader)6 Duration (java.time.Duration)6 TimeUnit (java.util.concurrent.TimeUnit)6 Attributes (io.opentelemetry.api.common.Attributes)5 SpanContext (io.opentelemetry.api.trace.SpanContext)5 TraceFlags (io.opentelemetry.api.trace.TraceFlags)5 TraceState (io.opentelemetry.api.trace.TraceState)5 RequestListener (io.opentelemetry.instrumentation.api.instrumenter.RequestListener)5 OpenTelemetryAssertions.attributeEntry (io.opentelemetry.sdk.testing.assertj.OpenTelemetryAssertions.attributeEntry)5 SdkLogEmitterProvider (io.opentelemetry.sdk.logs.SdkLogEmitterProvider)3 SdkTracerProvider (io.opentelemetry.sdk.trace.SdkTracerProvider)3 OpenTelemetrySdk (io.opentelemetry.sdk.OpenTelemetrySdk)2 Resource (io.opentelemetry.sdk.resources.Resource)2 SemanticAttributes (io.opentelemetry.semconv.trace.attributes.SemanticAttributes)2 Collections (java.util.Collections)2