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

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

Компании, где спрашивали
OkkoOkko

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

sobes.tech AI

Для настройки метрик в проектах на Go обычно использую Prometheus с библиотекой prometheus/client_golang. Метрики делятся на счетчики, гистограммы, гейджи и т.д., что позволяет отслеживать количество запросов, время обработки, ошибки и нагрузку.

Пример настройки счетчика запросов:

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

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

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

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

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

Что касается деплоя, обычно использую Kubernetes с Helm-чартами для управления конфигурацией и масштабированием. CI/CD настроен через GitLab CI или Jenkins, деплой происходит в облако (например, AWS EKS или GCP GKE). Для мониторинга и алертинга интегрирую Prometheus с Grafana и Alertmanager.