internal static object Run(OpenTelemetryShimOptions options) { // Enable OpenTelemetry for the source "MyCompany.MyProduct.MyWebServer" // and use a single pipeline with a custom MyProcessor, and Console exporter. using var tracerProvider = Sdk.CreateTracerProviderBuilder() .AddSource("MyCompany.MyProduct.MyWebServer") .SetResourceBuilder(ResourceBuilder.CreateDefault().AddService("MyServiceName")) .AddConsoleExporter() .Build(); // The above line is required only in applications // which decide to use OpenTelemetry. var tracer = TracerProvider.Default.GetTracer("MyCompany.MyProduct.MyWebServer"); using (var parentSpan = tracer.StartActiveSpan("parent span")) { parentSpan.SetAttribute("mystring", "value"); parentSpan.SetAttribute("myint", 100); parentSpan.SetAttribute("mydouble", 101.089); parentSpan.SetAttribute("mybool", true); parentSpan.UpdateName("parent span new name"); var childSpan = tracer.StartSpan("child span"); childSpan.AddEvent("sample event").SetAttribute("ch", "value").SetAttribute("more", "attributes"); childSpan.SetStatus(Status.Ok); childSpan.End(); } System.Console.WriteLine("Press Enter key to exit."); System.Console.ReadLine(); return(null); }
internal static object Run(OpenTelemetryShimOptions options) { // Enable OpenTelemetry for the source "MyCompany.MyProduct.MyWebServer" // and use a single pipeline with a custom MyProcessor, and Console exporter. using var tracerProvider = OpenTelemetrySdk.CreateTracerProvider( (builder) => builder.AddActivitySource("MyCompany.MyProduct.MyWebServer") .SetResource(Resources.CreateServiceResource("MyServiceName")) .UseConsoleExporter(opt => opt.DisplayAsJson = options.DisplayAsJson)); // The above line is required only in applications // which decide to use Open Telemetry. var tracer = TracerProvider.Default.GetTracer("MyCompany.MyProduct.MyWebServer"); var span = tracer.StartSpan("parent span"); span.SetAttribute("my", "value"); span.UpdateName("parent span new name"); var spanChild = tracer.StartSpan("child span"); spanChild.AddEvent("sample event").SetAttribute("ch", "value").SetAttribute("more", "attributes"); spanChild.End(); span.End(); System.Console.WriteLine("Press Enter key to exit."); return(null); }