opentelemetry-dotnet/test/Benchmarks/Exporter/OtlpHttpExporterBenchmarks.cs

94 lines
2.9 KiB
C#

// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
extern alias OpenTelemetryProtocol;
using System.Diagnostics;
using BenchmarkDotNet.Attributes;
using Benchmarks.Helper;
using OpenTelemetry;
using OpenTelemetry.Internal;
using OpenTelemetry.Tests;
using OpenTelemetryProtocol::OpenTelemetry.Exporter;
using OpenTelemetryProtocol::OpenTelemetry.Exporter.OpenTelemetryProtocol.Implementation;
using OpenTelemetryProtocol::OpenTelemetry.Exporter.OpenTelemetryProtocol.Implementation.ExportClient;
using OpenTelemetryProtocol::OpenTelemetry.Exporter.OpenTelemetryProtocol.Implementation.Transmission;
namespace Benchmarks.Exporter;
public class OtlpHttpExporterBenchmarks
{
private readonly byte[] buffer = new byte[1024 * 1024];
private IDisposable? server;
private string? serverHost;
private int serverPort;
private OtlpTraceExporter? exporter;
private Activity? activity;
private CircularBuffer<Activity>? activityBatch;
[Params(1, 10, 100)]
public int NumberOfBatches { get; set; }
[Params(10000)]
public int NumberOfSpans { get; set; }
[GlobalSetup]
public void GlobalSetup()
{
this.server = TestHttpServer.RunServer(
(ctx) =>
{
using (Stream receiveStream = ctx.Request.InputStream)
{
while (true)
{
if (receiveStream.Read(this.buffer, 0, this.buffer.Length) == 0)
{
break;
}
}
}
ctx.Response.StatusCode = 200;
ctx.Response.OutputStream.Close();
},
out this.serverHost,
out this.serverPort);
var options = new OtlpExporterOptions
{
Endpoint = new Uri($"http://{this.serverHost}:{this.serverPort}"),
};
this.exporter = new OtlpTraceExporter(
options,
new SdkLimitOptions(),
new ExperimentalOptions(),
new ProtobufOtlpExporterTransmissionHandler(new ProtobufOtlpHttpExportClient(options, options.HttpClientFactory(), "v1/traces"), options.TimeoutMilliseconds));
this.activity = ActivityHelper.CreateTestActivity();
this.activityBatch = new CircularBuffer<Activity>(this.NumberOfSpans);
}
[GlobalCleanup]
public void GlobalCleanup()
{
this.exporter?.Shutdown();
this.exporter?.Dispose();
this.server?.Dispose();
}
[Benchmark]
public void OtlpExporter_Batching()
{
for (int i = 0; i < this.NumberOfBatches; i++)
{
for (int c = 0; c < this.NumberOfSpans; c++)
{
this.activityBatch!.Add(this.activity!);
}
this.exporter!.Export(new Batch<Activity>(this.activityBatch!, this.NumberOfSpans));
}
}
}