Essential.OpenTelemetry.Exporter.OtlpFile
0.1.0
dotnet add package Essential.OpenTelemetry.Exporter.OtlpFile --version 0.1.0
NuGet\Install-Package Essential.OpenTelemetry.Exporter.OtlpFile -Version 0.1.0
<PackageReference Include="Essential.OpenTelemetry.Exporter.OtlpFile" Version="0.1.0" />
<PackageVersion Include="Essential.OpenTelemetry.Exporter.OtlpFile" Version="0.1.0" />
<PackageReference Include="Essential.OpenTelemetry.Exporter.OtlpFile" />
paket add Essential.OpenTelemetry.Exporter.OtlpFile --version 0.1.0
#r "nuget: Essential.OpenTelemetry.Exporter.OtlpFile, 0.1.0"
#:package Essential.OpenTelemetry.Exporter.OtlpFile@0.1.0
#addin nuget:?package=Essential.OpenTelemetry.Exporter.OtlpFile&version=0.1.0
#tool nuget:?package=Essential.OpenTelemetry.Exporter.OtlpFile&version=0.1.0
Essential OpenTelemetry OTLP File Exporter
OTLP File exporter for OpenTelemetry .NET that outputs OpenTelemetry signals to stdout (console) in JSONL format compatible with the OpenTelemetry Protocol File Exporter specification and the OpenTelemetry Collector JSON File Receiver.
This exporter is part of the Essential .NET OpenTelemetry project, which provides guidance, additional exporters, and extensions for .NET OpenTelemetry implementations.
NOTE: This alpha version only supports console output. Future versions will include configuration for specific output files, along with rotation options based on the Collector format.
Features
- Outputs logs, spans, and traces in OTLP protobuf JSON format (one JSON object per line)
- Compatible with OpenTelemetry Collector file exporter/receiver
- Supports structured logging with semantic attributes
Installation
Install the required NuGet packages via dotnet or another package manager:
dotnet add package OpenTelemetry.Extensions.Hosting
dotnet add package Essential.OpenTelemetry.Exporter.OtlpFile
Usage
The exporter can be configured as a standard OpenTelemetry exporter for a host based application.
- Add the required packages
- Reference the required namespaces
- Clear the default logging providers (so there is no other console output)
- Add the OtlpFileExporter
using System;
using Essential.OpenTelemetry;
using Microsoft.AspNetCore.Builder;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using OpenTelemetry.Metrics;
using OpenTelemetry.Trace;
var builder = WebApplication.CreateBuilder(args);
// Clear default logging
builder.Logging.ClearProviders();
// Add OpenTelemetry with OTLP File exporter
builder
.Services.AddOpenTelemetry()
.WithLogging(logging =>
{
logging.AddOtlpFileExporter();
})
.WithTracing(tracing =>
{
tracing.AddAspNetCoreInstrumentation().AddOtlpFileExporter();
})
.WithMetrics(metrics =>
{
metrics
.AddAspNetCoreInstrumentation()
.AddView(instrument =>
instrument.Name.StartsWith("http.server.request", StringComparison.Ordinal)
? null
: MetricStreamConfiguration.Drop
)
.AddOtlpFileExporter(options => { }, exportIntervalMilliseconds: 60_000);
});
var app = builder.Build();
app.MapGet("/", () => "Hello World!");
app.Run();
Output Format
The exporter outputs one JSON object per line in OTLP protobuf JSON format. The example is here is formatted for readability, but is output as a single line (JSONL) by the exporter.
{
"resourceLogs": [
{
"resource": { "attributes": [] },
"scopeLogs": [
{
"scope": { "name": "Program" },
"logRecords": [
{
"timeUnixNano": "1771035371041000000",
"observedTimeUnixNano": "1771035371041000000",
"severityNumber": 9,
"severityText": "Information",
"body": { "stringValue": "Hello from Alice" },
"attributes": [
{ "key": "Name", "value": { "stringValue": "Alice" } }
]
}
]
}
]
}
]
}
Using with OpenTelemetry Collector
You can pipe the output to a file and use it with the OTLP JSON File Receiver:
dotnet run > logs.jsonl
License
Essential.OpenTelemetry OtlpFile Exporter - OTLP JSON file output for OpenTelemetry logs, traces, and metrics. Copyright (C) 2026 Gryphon Technology Pty Ltd
This library is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License and GNU General Public License for more details.
You should have received a copy of the GNU Lesser General Public License and GNU General Public License along with this library. If not, see https://www.gnu.org/licenses/.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Google.Protobuf (>= 3.28.3)
- OpenTelemetry (>= 1.15.0)
- System.Text.Json (>= 8.0.5)
-
.NETStandard 2.1
- Google.Protobuf (>= 3.28.3)
- OpenTelemetry (>= 1.15.0)
- System.Text.Json (>= 8.0.5)
-
net10.0
- Google.Protobuf (>= 3.28.3)
- Microsoft.Extensions.Hosting (>= 10.0.0)
- OpenTelemetry (>= 1.15.0)
-
net8.0
- Google.Protobuf (>= 3.28.3)
- Microsoft.Extensions.Hosting (>= 8.0.0)
- OpenTelemetry (>= 1.15.0)
-
net9.0
- Google.Protobuf (>= 3.28.3)
- Microsoft.Extensions.Hosting (>= 9.0.0)
- OpenTelemetry (>= 1.15.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Essential.OpenTelemetry.Exporter.OtlpFile:
| Package | Downloads |
|---|---|
|
Cngot.Extensions.Logger.OpenTelemetry
日志 |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 0.1.0 | 157 | 2/28/2026 |