You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

54 lines
1.5 KiB

5 years ago
  1. package main
  2. import (
  3. "log"
  4. "net/http"
  5. "strconv"
  6. "time"
  7. )
  8. func checker(services []Service) {
  9. log.Println("serverChecker started")
  10. log.Println(services)
  11. ticker := time.NewTicker(time.Second * time.Duration(int64(config.SleepTime)))
  12. for _ = range ticker.C {
  13. for k, service := range services {
  14. resp, err := checkUrl(service.Url)
  15. if err != nil {
  16. if service.Counter == 0 {
  17. msg := "⚠️ Service " + service.Name + ", with url " + service.Url + " is not responding"
  18. matrixSendMsg(msg)
  19. }
  20. services[k].Counter = services[k].Counter + 1
  21. } else if resp.StatusCode != service.StatusCode {
  22. if service.Counter == 0 {
  23. msg := "⚠️ Service " + service.Name + ", with url " + service.Url + " has returned a non expected StatusCode: " + strconv.Itoa(resp.StatusCode) + ", expected: " + strconv.Itoa(service.StatusCode)
  24. matrixSendMsg(msg)
  25. }
  26. services[k].Counter = services[k].Counter + 1
  27. } else {
  28. if services[k].Counter != 0 {
  29. msg := "✔️ Service " + service.Name + ", with url " + service.Url + " is alive again"
  30. matrixSendMsg(msg)
  31. }
  32. services[k].Counter = 0
  33. }
  34. if services[k].Counter > config.Retry {
  35. msg := "⚠️ Service " + services[k].Name + ", with url " + services[k].Url + " is still failing"
  36. matrixSendNotice(msg)
  37. services[k].Counter = 1
  38. }
  39. }
  40. }
  41. }
  42. func checkUrl(url string) (*http.Response, error) {
  43. timeout := time.Duration(1 * time.Second)
  44. client := http.Client{
  45. Timeout: timeout,
  46. }
  47. resp, err := client.Get(url)
  48. return resp, err
  49. }