You've already forked postgres_exporter
mirror of
https://github.com/prometheus-community/postgres_exporter.git
synced 2025-08-14 01:02:26 +03:00
WIP: Add prelim multi-target support
- Remove multi server support from new collector package - Add http handler for multi-target support Signed-off-by: Joe Adams <github@joeadams.io>
This commit is contained in:
@@ -85,16 +85,17 @@ func main() {
|
||||
return
|
||||
}
|
||||
|
||||
dsn, err := getDataSources()
|
||||
dsns, err := getDataSources()
|
||||
if err != nil {
|
||||
level.Error(logger).Log("msg", "Failed reading data sources", "err", err.Error())
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
if len(dsn) == 0 {
|
||||
level.Error(logger).Log("msg", "Couldn't find environment variables describing the datasource to use")
|
||||
os.Exit(1)
|
||||
}
|
||||
// TODO(@sysadmind): Remove this with multi-target support
|
||||
// if len(dsn) == 0 {
|
||||
// level.Error(logger).Log("msg", "Couldn't find environment variables describing the datasource to use")
|
||||
// os.Exit(1)
|
||||
// }
|
||||
|
||||
opts := []ExporterOpt{
|
||||
DisableDefaultMetrics(*disableDefaultMetrics),
|
||||
@@ -106,7 +107,7 @@ func main() {
|
||||
IncludeDatabases(*includeDatabases),
|
||||
}
|
||||
|
||||
exporter := NewExporter(dsn, opts...)
|
||||
exporter := NewExporter(dsns, opts...)
|
||||
defer func() {
|
||||
exporter.servers.Close()
|
||||
}()
|
||||
@@ -115,6 +116,12 @@ func main() {
|
||||
|
||||
prometheus.MustRegister(exporter)
|
||||
|
||||
// TODO(@sysadmind): Remove this with multi-target support. We are removing multiple DSN support
|
||||
dsn := ""
|
||||
if len(dsns) > 0 {
|
||||
dsn = dsns[0]
|
||||
}
|
||||
|
||||
pe, err := collector.NewPostgresCollector(
|
||||
logger,
|
||||
dsn,
|
||||
@@ -122,9 +129,9 @@ func main() {
|
||||
)
|
||||
if err != nil {
|
||||
level.Error(logger).Log("msg", "Failed to create PostgresCollector", "err", err.Error())
|
||||
os.Exit(1)
|
||||
} else {
|
||||
prometheus.MustRegister(pe)
|
||||
}
|
||||
prometheus.MustRegister(pe)
|
||||
|
||||
http.Handle(*metricPath, promhttp.Handler())
|
||||
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
|
||||
@@ -132,6 +139,8 @@ func main() {
|
||||
w.Write(landingPage) // nolint: errcheck
|
||||
})
|
||||
|
||||
http.HandleFunc("/probe", handleProbe(logger))
|
||||
|
||||
level.Info(logger).Log("msg", "Listening on address", "address", *listenAddress)
|
||||
srv := &http.Server{Addr: *listenAddress}
|
||||
if err := web.ListenAndServe(srv, *webConfig, logger); err != nil {
|
||||
|
Reference in New Issue
Block a user