Golang: реализует проверку работоспособности http-сервера. gocraft/ здоровье

Я хочу проверить работоспособность моего сервиса, имея метрики каждой конечной точки. Мой сервис вызывает некоторые другие сервисы и получает код Json, я делаю с ним шаблоны, а затем отправляю его на http.ResponseWriter.

Я искал и нашел этот пакет "gocraft/health", но я не совсем понял, как он работает.

Есть ли другой способ или пакет для генерации метрик, или я должен просто использовать "gocraft/health".

заранее спасибо

1 ответ

Решение

Наконец, я выбираю "gocraft / health", отличную библиотеку.

Пример использования:

package main

import (
    "log"
    "net/http"
    "os"
    "time"

    "github.com/gocraft/health"
)

//should be global Var
var stream = health.NewStream()

func main() {
    // Log to stdout!
    stream.AddSink(&health.WriterSink{os.Stdout})
    // Make sink and add it to stream
    sink := health.NewJsonPollingSink(time.Minute*5, time.Minute*20)
    stream.AddSink(sink)
    // Start the HTTP server! This will expose metrics via a JSON API.
    adr := "127.0.0.1:5001"
    sink.StartServer(adr)

    http.HandleFunc("/api/getVastPlayer", vastPlayer)
    log.Println("Listening...")
    panic(http.ListenAndServe(":2001", nil))
}

В соответствии с приведенными выше параметрами инициализации ваши показатели агрегируются в 5-минутные порции. Мы будем хранить в памяти данные за 20 минут. Ничто никогда не сохраняется на диске.

Вы можете создать столько рабочих мест, сколько захотите

func vastPlayer(w http.ResponseWriter, r *http.Request) {
  job_1 := stream.NewJob("/api/getVastPlayer")

  ...
  ...

  if bol {
    job_1.Complete(health.Success)
  } else {
    job_1.Complete(health.Error)
  }
}

Как только вы запустите свое приложение, оно будет отображать метрики через JSON API. Вы можете просматривать /health конечная точка (например, 127.0.0.1:5001/health) чтобы увидеть метрику. Вы получите что-то подобное:

{
  "instance_id": "sd-69536.29342",
  "interval_duration": 86400000000000,
  "aggregations": [
    {
      "interval_start": "2015-06-11T02:00:00+02:00",
      "serial_number": 1340,
      "jobs": {
        "/api/getVastPlayer": {
          "timers": {},
          "events": {},
          "event_errs": {},
          "count": 1328,
          "nanos_sum": 140160794784,
          "nanos_sum_squares": 9.033775178022173E+19,
          "nanos_min": 34507863,
          "nanos_max": 2736850494,
          "count_success": 62,
          "count_validation_error": 1266,
          "count_panic": 0,
          "count_error": 0,
          "count_junk": 0
        },
        "timers": {},
        "events": {},
        "event_errs": {}
      }
    }
  ]
}

Для получения дополнительной информации и функциональности проверьте эту ссылку:

https://github.com/gocraft/health

Если вы столкнулись с этим вопросом, потому что искали /healthконечная точка, скоро появится RFC для проверок работоспособности: https://github.com/inadarei/rfc-healthcheck

И есть библиотека Go health-goдля раскрытия конечных точек работоспособности, соответствующих этому RFC: https://github.com/nelkinda/health-go

Пример:

package main

import (
    "github.com/nelkinda/health-go"
    "net/http"
)

func main() {
    // 1. Create the health Handler.
    h := health.New(health.Health{Version: "1", ReleaseID: "1.0.0-SNAPSHOT"}) 

    // 2. Add the handler to your mux/server.
    http.HandleFunc("/health", h.Handler)

    // 3. Start your server.
    http.ListenAndServe(":80", nil)
}

Он расширяемый и поддерживает ряд встроенных проверок, таких как время безотказной работы и sysinfo.

Отказ от ответственности: я автор health-go.

Другие вопросы по тегам