IT заметки по программированию
IT заметки по программированию
IT заметки по программированию
IT заметки по программированию

В Go для передачи контекста трассировки между архитектурными слоями обычно используется стандартный механизм контекста (context.Context) совместно с инструментами OpenTelemetry (Otel). Вот пошаговое руководство, как это сделать:...

продолжить чтение


TraceQL — это язык запросов, используемый в Grafana Tempo для фильтрации и анализа трассировок. Он позволяет выбирать трейсы и их части (спаны) на основе заданных условий. Ниже приводится описание синтаксиса TraceQL, ключевых элементов языка и примеры использования....

продолжить чтение


OpenTelemetry трассировщик в Go спроектирован так, чтобы минимизировать влияние на основной процесс выполнения программы. Он это достигает за счёт асинхронной обработки данных, эффективного управления буферизацией и отправкой, а также оптимизированного дизайна API. Вот основные принципы, которые помогают ему не тормозить основной процесс:...

продолжить чтение


В OpenTelemetry Go, когда вы создаете новый спан, его родительский идентификатор указывается автоматически через контекст (context.Context). Таким образом, если вы хотите задать родительский идентификатор для нового спана, вам нужно передать контекст, содержащий уже существующий спан, в качестве родителя....

продолжить чтение


В OpenTelemetry Go не нужно создавать новый экземпляр трассировщика для каждого трейса. Обычно, один и тот же трассировщик (tracer) используется для создания нескольких спанов (spans) в рамках одной трассировки (trace)....

продолжить чтение


otel.SetTracerProvider() устанавливает глобальный провайдер трассировки, который становится доступным во всей программе. Это означает, что после вызова этой функции любой пакет или часть кода, использующая OpenTelemetry SDK, сможет получить доступ к этому провайдеру и создавать трейсы и спаны, не создавая отдельный провайдер в каждом пакете....

продолжить чтение


OpenTelemetry Collector — это универсальный агент и сервер для сбора, обработки и экспорта телеметрических данных, таких как трассировки, метрики и логи. Он предназначен для упрощения работы с телеметрией, обеспечивая гибкость и масштабируемость. Collector играет ключевую роль в архитектуре OpenTelemetry, выступая посредником между приложениями, инструментированными OpenTelemetry SDK, и системами хранения и анализа, такими как Prometheus,......

продолжить чтение


Официальная документация OpenTelemetry для Go SDK предоставляет подробные инструкции по настройке и использованию трассировок, метрик и контекстов. Вы можете найти документацию на GitHub и на официальном сайте OpenTelemetry....

продолжить чтение


OpenTelemetry — это открытый стандарт и инструмент для сбора, обработки и экспорта данных о производительности и диагностике из приложений. Он позволяет разработчикам и инженерам собирать метрики, логи и трассировки из распределённых систем, объединяя эти данные для мониторинга и анализа....

продолжить чтение


Спецификация W3C Trace Context — это стандарт для передачи контекста трассировки через распределённые системы. Она определяет формат заголовков HTTP-запросов, которые позволяют сервисам обмениваться информацией о трассировках, таких как Trace ID и Span ID, в рамках одной или нескольких систем. Цель стандарта — обеспечить совместимость между инструментами трассировки, такими как OpenTelemetry, Jaeger, Zipkin, и......

продолжить чтение


Чтобы добавить ID трассировки для OpenTelemetry в HAProxy и передать его клиенту (или между сервисами), можно использовать настройку добавления и обработки HTTP-заголовков. Это позволяет вставить заголовок traceparent в соответствии со спецификацией W3C Trace Context....

продолжить чтение


Пакет envconfig в Go предназначен для удобной загрузки переменных окружения в структуры. Это популярный инструмент, который позволяет легко маппить переменные окружения на заранее определённые поля структуры и упрощает управление конфигурацией приложения....

продолжить чтение