forked from open-telemetry/opentelemetry-dotnet
-
Notifications
You must be signed in to change notification settings - Fork 0
/
TestLogs.cs
124 lines (112 loc) · 5.37 KB
/
TestLogs.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
using Microsoft.Extensions.Logging;
using OpenTelemetry;
using OpenTelemetry.Logs;
namespace Examples.Console;
internal class TestLogs
{
internal static int Run(LogsOptions options)
{
using var loggerFactory = LoggerFactory.Create(builder =>
{
builder.AddOpenTelemetry((opt) =>
{
opt.IncludeFormattedMessage = true;
opt.IncludeScopes = true;
if ("otlp".Equals(options.UseExporter, StringComparison.OrdinalIgnoreCase))
{
/*
* 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 -p 4318:4318 -v $(pwd):/cfg otel/opentelemetry-collector:0.48.0 --config=/cfg/otlp-collector-example/config.yaml
*
* - On Windows use:
* docker run --rm -it -p 4317:4317 -p 4318:4318 -v "%cd%":/cfg otel/opentelemetry-collector:0.48.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 -e http://localhost:4317
*
* The OpenTelemetry Collector will output all received logs to the stdout of its terminal.
*
*/
var protocol = OpenTelemetry.Exporter.OtlpExportProtocol.Grpc;
if (!string.IsNullOrEmpty(options.Protocol))
{
switch (options.Protocol.Trim())
{
case "grpc":
protocol = OpenTelemetry.Exporter.OtlpExportProtocol.Grpc;
break;
case "http/protobuf":
protocol = OpenTelemetry.Exporter.OtlpExportProtocol.HttpProtobuf;
break;
default:
System.Console.WriteLine($"Export protocol {options.Protocol} is not supported. Default protocol 'grpc' will be used.");
break;
}
}
else
{
System.Console.WriteLine("Protocol is null or empty. Default protocol 'grpc' will be used.");
}
var processorType = ExportProcessorType.Batch;
if (!string.IsNullOrEmpty(options.ProcessorType))
{
switch (options.ProcessorType.Trim())
{
case "batch":
processorType = ExportProcessorType.Batch;
break;
case "simple":
processorType = ExportProcessorType.Simple;
break;
default:
System.Console.WriteLine($"Export processor type {options.ProcessorType} is not supported. Default processor type 'batch' will be used.");
break;
}
}
else
{
System.Console.WriteLine("Processor type is null or empty. Default processor type 'batch' will be used.");
}
opt.AddOtlpExporter((exporterOptions, processorOptions) =>
{
exporterOptions.Protocol = protocol;
if (!string.IsNullOrWhiteSpace(options.Endpoint))
{
exporterOptions.Endpoint = new Uri(options.Endpoint);
}
if (processorType == ExportProcessorType.Simple)
{
processorOptions.ExportProcessorType = ExportProcessorType.Simple;
}
else
{
processorOptions.ExportProcessorType = ExportProcessorType.Batch;
processorOptions.BatchExportProcessorOptions = new BatchExportLogRecordProcessorOptions() { ScheduledDelayMilliseconds = options.ScheduledDelayInMilliseconds };
}
});
}
else
{
opt.AddConsoleExporter();
}
});
});
var logger = loggerFactory.CreateLogger<Program>();
using (logger.BeginScope("{city}", "Seattle"))
using (logger.BeginScope("{storeType}", "Physical"))
{
logger.LogInformation("Hello from {name} {price}.", "tomato", 2.99);
}
return 0;
}
}