diff --git a/cmd/jetson-exporter.go b/cmd/jetson-exporter.go index f4949d8..ded09c1 100644 --- a/cmd/jetson-exporter.go +++ b/cmd/jetson-exporter.go @@ -2,6 +2,10 @@ package main import ( "bufio" + "github.com/alecthomas/kingpin/v2" + "github.com/prometheus/common/promlog/flag" + "github.com/prometheus/common/version" + "github.com/prometheus/exporter-toolkit/web" "net/http" "os" "os/exec" @@ -12,6 +16,7 @@ import ( "github.com/prometheus/client_golang/prometheus/promauto" "github.com/prometheus/client_golang/prometheus/promhttp" "github.com/prometheus/common/promlog" + webflag "github.com/prometheus/exporter-toolkit/web/kingpinflag" ) var ( @@ -86,7 +91,21 @@ var ( ) func main() { - logger := promlog.New(&promlog.Config{}) + + var ( + webConfig = webflag.AddFlags(kingpin.CommandLine, ":9102") + metricsPath = kingpin.Flag("web.telemetry-path", "Path under which to expose metrics.").Default("/metrics").String() + ) + + promlogConfig := &promlog.Config{} + flag.AddFlags(kingpin.CommandLine, promlogConfig) + kingpin.Version(version.Print("jetson-exporter")) + kingpin.HelpFlag.Short('h') + kingpin.Parse() + logger := promlog.New(promlogConfig) + + level.Info(logger).Log("msg", "Starting jetson-exporter", "version", version.Info()) + level.Info(logger).Log("msg", "Build context", "context", version.BuildContext()) go func() { cmd := exec.Command("tegrastats") @@ -141,15 +160,13 @@ func main() {