-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.go
More file actions
82 lines (70 loc) · 1.96 KB
/
main.go
File metadata and controls
82 lines (70 loc) · 1.96 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package main
import (
"context"
"flag"
"log"
"net/http"
"os"
"os/signal"
"syscall"
"time"
"prometheus-s3-exporter/pkg/config"
"prometheus-s3-exporter/pkg/exporter"
"github.com/prometheus/client_golang/prometheus/promhttp"
)
var (
version = "dev"
commit = ""
date = ""
)
func main() {
cfgPath := flag.String("config", "config.toml", "Path to TOML config file")
listen := flag.String("listen", "", "Override listen address from config (e.g. :9877)")
flag.Parse()
log.Printf("prometheus-s3-exporter version=%s commit=%s date=%s", version, commit, date)
cfg, err := config.Load(*cfgPath)
if err != nil {
log.Fatalf("failed to load config: %v", err)
}
if *listen != "" {
cfg.Server.ListenAddress = *listen
}
exp, err := exporter.NewManager(cfg)
if err != nil {
log.Fatalf("failed to init exporter: %v", err)
}
// Start background collectors
exp.Start()
defer exp.Stop()
mux := http.NewServeMux()
mux.Handle(cfg.Server.MetricsPath, promhttp.Handler())
mux.HandleFunc("/-/ready", func(w http.ResponseWriter, r *http.Request) {
if exp.Ready() {
w.WriteHeader(http.StatusOK)
_, _ = w.Write([]byte("ok"))
return
}
w.WriteHeader(http.StatusServiceUnavailable)
_, _ = w.Write([]byte("not ready"))
})
mux.HandleFunc("/-/healthy", func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusOK)
_, _ = w.Write([]byte("ok"))
})
srv := &http.Server{Addr: cfg.Server.ListenAddress, Handler: mux}
go func() {
log.Printf("listening on %s, metrics at %s", cfg.Server.ListenAddress, cfg.Server.MetricsPath)
if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed {
log.Fatalf("http server error: %v", err)
}
}()
// Graceful shutdown
sigc := make(chan os.Signal, 1)
signal.Notify(sigc, os.Interrupt, syscall.SIGTERM)
<-sigc
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()
if err := srv.Shutdown(ctx); err != nil {
log.Printf("server shutdown error: %v", err)
}
}