Add OTLP LogExporter example (#2481)
This commit is contained in:
parent
ed814d1d6d
commit
6664781c76
|
|
@ -37,5 +37,6 @@
|
||||||
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.Jaeger\OpenTelemetry.Exporter.Jaeger.csproj" />
|
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.Jaeger\OpenTelemetry.Exporter.Jaeger.csproj" />
|
||||||
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.InMemory\OpenTelemetry.Exporter.InMemory.csproj" />
|
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.InMemory\OpenTelemetry.Exporter.InMemory.csproj" />
|
||||||
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.Prometheus\OpenTelemetry.Exporter.Prometheus.csproj" />
|
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.Prometheus\OpenTelemetry.Exporter.Prometheus.csproj" />
|
||||||
|
<ProjectReference Include="$(RepoRoot)\src\OpenTelemetry.Exporter.OpenTelemetryProtocol.Logs\OpenTelemetry.Exporter.OpenTelemetryProtocol.Logs.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
</Project>
|
</Project>
|
||||||
|
|
|
||||||
|
|
@ -43,12 +43,13 @@ namespace Examples.Console
|
||||||
/// <param name="args">Arguments from command line.</param>
|
/// <param name="args">Arguments from command line.</param>
|
||||||
public static void Main(string[] args)
|
public static void Main(string[] args)
|
||||||
{
|
{
|
||||||
Parser.Default.ParseArguments<JaegerOptions, ZipkinOptions, PrometheusOptions, MetricsOptions, GrpcNetClientOptions, HttpClientOptions, RedisOptions, ZPagesOptions, ConsoleOptions, OpenTelemetryShimOptions, OpenTracingShimOptions, OtlpOptions, InMemoryOptions>(args)
|
Parser.Default.ParseArguments<JaegerOptions, ZipkinOptions, PrometheusOptions, MetricsOptions, LogsOptions, GrpcNetClientOptions, HttpClientOptions, RedisOptions, ZPagesOptions, ConsoleOptions, OpenTelemetryShimOptions, OpenTracingShimOptions, OtlpOptions, InMemoryOptions>(args)
|
||||||
.MapResult(
|
.MapResult(
|
||||||
(JaegerOptions options) => TestJaegerExporter.Run(options.Host, options.Port),
|
(JaegerOptions options) => TestJaegerExporter.Run(options.Host, options.Port),
|
||||||
(ZipkinOptions options) => TestZipkinExporter.Run(options.Uri),
|
(ZipkinOptions options) => TestZipkinExporter.Run(options.Uri),
|
||||||
(PrometheusOptions options) => TestPrometheusExporter.Run(options.Port, options.DurationInMins),
|
(PrometheusOptions options) => TestPrometheusExporter.Run(options.Port, options.DurationInMins),
|
||||||
(MetricsOptions options) => TestMetrics.Run(options),
|
(MetricsOptions options) => TestMetrics.Run(options),
|
||||||
|
(LogsOptions options) => TestLogs.Run(options),
|
||||||
(GrpcNetClientOptions options) => TestGrpcNetClient.Run(),
|
(GrpcNetClientOptions options) => TestGrpcNetClient.Run(),
|
||||||
(HttpClientOptions options) => TestHttpClient.Run(),
|
(HttpClientOptions options) => TestHttpClient.Run(),
|
||||||
(RedisOptions options) => TestRedis.Run(options.Uri),
|
(RedisOptions options) => TestRedis.Run(options.Uri),
|
||||||
|
|
@ -169,6 +170,13 @@ namespace Examples.Console
|
||||||
public string Protocol { get; set; }
|
public string Protocol { get; set; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Verb("logs", HelpText = "Specify the options required to test Logs")]
|
||||||
|
internal class LogsOptions
|
||||||
|
{
|
||||||
|
[Option("useExporter", Default = "otlp", HelpText = "Options include otlp or console.", Required = false)]
|
||||||
|
public string UseExporter { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
[Verb("inmemory", HelpText = "Specify the options required to test InMemory Exporter")]
|
[Verb("inmemory", HelpText = "Specify the options required to test InMemory Exporter")]
|
||||||
internal class InMemoryOptions
|
internal class InMemoryOptions
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,79 @@
|
||||||
|
// <copyright file="TestLogs.cs" company="OpenTelemetry Authors">
|
||||||
|
// Copyright The OpenTelemetry Authors
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
// </copyright>
|
||||||
|
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Threading;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using OpenTelemetry;
|
||||||
|
using OpenTelemetry.Logs;
|
||||||
|
|
||||||
|
namespace Examples.Console
|
||||||
|
{
|
||||||
|
internal class TestLogs
|
||||||
|
{
|
||||||
|
internal static object Run(LogsOptions options)
|
||||||
|
{
|
||||||
|
using var loggerFactory = LoggerFactory.Create(builder =>
|
||||||
|
{
|
||||||
|
builder.AddOpenTelemetry((opt) =>
|
||||||
|
{
|
||||||
|
opt.IncludeFormattedMessage = true;
|
||||||
|
if (options.UseExporter.ToLower() == "otlp")
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Prerequisite to run this example:
|
||||||
|
* Set up an OpenTelemetry Collector to run on local docker.
|
||||||
|
*
|
||||||
|
* Open a terminal window at the examples/Console/ directory and
|
||||||
|
* launch the OpenTelemetry Collector with an OTLP receiver, by running:
|
||||||
|
*
|
||||||
|
* - On Unix based systems use:
|
||||||
|
* docker run --rm -it -p 4317:4317 -v $(pwd):/cfg otel/opentelemetry-collector:0.33.0 --config=/cfg/otlp-collector-example/config.yaml
|
||||||
|
*
|
||||||
|
* - On Windows use:
|
||||||
|
* docker run --rm -it -p 4317:4317 -v "%cd%":/cfg otel/opentelemetry-collector:0.33.0 --config=/cfg/otlp-collector-example/config.yaml
|
||||||
|
*
|
||||||
|
* Open another terminal window at the examples/Console/ directory and
|
||||||
|
* launch the OTLP example by running:
|
||||||
|
*
|
||||||
|
* dotnet run logs --useExporter otlp
|
||||||
|
*
|
||||||
|
* The OpenTelemetry Collector will output all received metrics to the stdout of its terminal.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
// Adding the OtlpExporter creates a GrpcChannel.
|
||||||
|
// This switch must be set before creating a GrpcChannel/HttpClient when calling an insecure gRPC service.
|
||||||
|
// See: https://docs.microsoft.com/aspnet/core/grpc/troubleshoot#call-insecure-grpc-services-with-net-core-client
|
||||||
|
AppContext.SetSwitch("System.Net.Http.SocketsHttpHandler.Http2UnencryptedSupport", true);
|
||||||
|
|
||||||
|
opt.AddOtlpExporter();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
opt.AddConsoleExporter();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
var logger = loggerFactory.CreateLogger<Program>();
|
||||||
|
logger.LogInformation("Hello from {name} {price}.", "tomato", 2.99);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -21,3 +21,6 @@ service:
|
||||||
metrics:
|
metrics:
|
||||||
receivers: [otlp]
|
receivers: [otlp]
|
||||||
exporters: [logging]
|
exporters: [logging]
|
||||||
|
logs:
|
||||||
|
receivers: [otlp]
|
||||||
|
exporters: [logging]
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue