Sobes.tech
Назад к вопросам
Senior
4

Какие инструменты использовали для наблюдаемости сервисов?

Компании, где спрашивали
Финтехробот

Ответ от нейросети

sobes.tech AI

Для наблюдаемости сервисов на Go обычно использую комбинацию нескольких инструментов:

  • Prometheus для сбора метрик: легко интегрируется с Go через клиентскую библиотеку, позволяет собирать кастомные метрики и строить дашборды.
  • Grafana для визуализации метрик из Prometheus.
  • Jaeger или OpenTelemetry для распределённого трейсинга, что помогает понять задержки и цепочки вызовов между сервисами.
  • Logrus или Zap для структурированного логирования с последующим агрегированием в ELK-стек (Elasticsearch, Logstash, Kibana) или Loki.

Пример интеграции Prometheus в Go:

import (
    "github.com/prometheus/client_golang/prometheus"
    "github.com/prometheus/client_golang/prometheus/promhttp"
    "net/http"
)

var requestCount = prometheus.NewCounterVec(
    prometheus.CounterOpts{
        Name: "http_requests_total",
        Help: "Количество HTTP запросов",
    },
    []string{"path"},
)

func init() {
    prometheus.MustRegister(requestCount)
}

func handler(w http.ResponseWriter, r *http.Request) {
    requestCount.WithLabelValues(r.URL.Path).Inc()
    w.Write([]byte("Hello, world!"))
}

func main() {
    http.HandleFunc("/", handler)
    http.Handle("/metrics", promhttp.Handler())
    http.ListenAndServe(":8080", nil)
}

Такой стек позволяет получить полное представление о состоянии и производительности сервисов.