Как я могу отправить трассировки в Jaeger с C #?

#c# #jaeger

#c# #jaeger

Вопрос:

Я пытаюсь использовать пакет Jaeger для отправки трассировок в Jaeger из приложения на C #.

В документации jaeger-client-csharp нет минимальных примеров, но из того, что я прочитал, я думаю, что это должно сработать.

 using Jaeger;
using Jaeger.Samplers;

namespace jaegertest
{
    class Program
    {
        static void Main(string[] args)
        {
            var tracer = new Tracer.Builder("my-service")
                .WithSampler(new ConstSampler(true))
                .Build();

            using (var scope = tracer.BuildSpan("foo").StartActive(true))
            {
                System.Threading.Thread.Sleep(1000);
            }
        }
    }
}
  

У меня есть jaeger-all-in-one.exe выполняется, но когда я запускаю этот код, нет никаких признаков каких-либо новых следов. Я пытался вручную настроить сэмплеры, отправителей, репортеров и т. Д., Но ничего из того, что я пробовал, не сработало. Что мне нужно добавить, чтобы мои трассировки отображались в Jaeger?

Ответ №1:

Это самый простой рабочий пример, который я смог найти.

 using Jaeger;
using Jaeger.Reporters;
using Jaeger.Samplers;
using Jaeger.Senders.Thrift;

namespace jaegertest
{
    class Program
    {
        static void Main(string[] args)
        {
            var tracer = new Tracer.Builder("my-service")
                .WithSampler(new ConstSampler(true))
                .WithReporter(new RemoteReporter.Builder()
                    .WithSender(new UdpSender())
                    .Build())
                .Build();

            using (var scope = tracer.BuildSpan("foo").StartActive(true))
            {
                System.Threading.Thread.Sleep(1000);
            }

            tracer.Dispose();
        }
    }
}
  

Вот более реалистичный пример, который строит трассировщик из конфигурации.

 using Jaeger;
using Jaeger.Samplers;
using Jaeger.Senders;
using Jaeger.Senders.Thrift;
using Microsoft.Extensions.Logging;

namespace jaegertest
{
    class Program
    {
        static void Main(string[] args)
        {
            var loggerFactory = new LoggerFactory();

            var samplerConfiguration = new Configuration.SamplerConfiguration(loggerFactory)
                .WithType(ConstSampler.Type)
                .WithParam(1);

            var senderResolver = new SenderResolver(loggerFactory)
                .RegisterSenderFactory<ThriftSenderFactory>();

            var senderConfiguration = new Configuration.SenderConfiguration(loggerFactory)
                .WithSenderResolver(senderResolver);

            var reporterConfiguration = new Configuration.ReporterConfiguration(loggerFactory)
                .WithSender(senderConfiguration)
                .WithLogSpans(true);

            var tracer = (Tracer)new Configuration("my-service", loggerFactory)
                .WithSampler(samplerConfiguration)
                .WithReporter(reporterConfiguration)
                .GetTracer();

            using (var scope = tracer.BuildSpan("foo").StartActive(true))
            {
                System.Threading.Thread.Sleep(1000);
            }

            tracer.Dispose();
        }
    }
}