mirror of
https://github.com/prometheus-community/ipmi_exporter
synced 2024-12-23 14:32:16 +00:00
67041ef633
- Move every collector into its own file - Move FreeIPMI code into own package - Allow more customization of commands executed by collectors - Split up documentation, so README is a little less overwhelming A single commit message does not do justice to the amount of changes here, but hey... :)
106 lines
2.2 KiB
Go
106 lines
2.2 KiB
Go
package main
|
|
|
|
import (
|
|
"path"
|
|
"time"
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
"github.com/prometheus/common/log"
|
|
|
|
"github.com/soundcloud/ipmi_exporter/freeipmi"
|
|
)
|
|
|
|
const (
|
|
namespace = "ipmi"
|
|
targetLocal = ""
|
|
)
|
|
|
|
type collector interface {
|
|
Name() CollectorName
|
|
Cmd() string
|
|
Args() []string
|
|
Collect(output freeipmi.Result, ch chan<- prometheus.Metric, target ipmiTarget) (int, error)
|
|
}
|
|
|
|
type metaCollector struct {
|
|
target string
|
|
module string
|
|
config *SafeConfig
|
|
}
|
|
|
|
type ipmiTarget struct {
|
|
host string
|
|
config IPMIConfig
|
|
}
|
|
|
|
var (
|
|
upDesc = prometheus.NewDesc(
|
|
prometheus.BuildFQName(namespace, "", "up"),
|
|
"'1' if a scrape of the IPMI device was successful, '0' otherwise.",
|
|
[]string{"collector"},
|
|
nil,
|
|
)
|
|
|
|
durationDesc = prometheus.NewDesc(
|
|
prometheus.BuildFQName(namespace, "scrape_duration", "seconds"),
|
|
"Returns how long the scrape took to complete in seconds.",
|
|
nil,
|
|
nil,
|
|
)
|
|
)
|
|
|
|
// Describe implements Prometheus.Collector.
|
|
func (c metaCollector) Describe(ch chan<- *prometheus.Desc) {
|
|
// all metrics are described ad-hoc
|
|
}
|
|
|
|
func markCollectorUp(ch chan<- prometheus.Metric, name string, up int) {
|
|
ch <- prometheus.MustNewConstMetric(
|
|
upDesc,
|
|
prometheus.GaugeValue,
|
|
float64(up),
|
|
name,
|
|
)
|
|
}
|
|
|
|
// Collect implements Prometheus.Collector.
|
|
func (c metaCollector) Collect(ch chan<- prometheus.Metric) {
|
|
start := time.Now()
|
|
defer func() {
|
|
duration := time.Since(start).Seconds()
|
|
log.Debugf("Scrape of target %s took %f seconds.", targetName(c.target), duration)
|
|
ch <- prometheus.MustNewConstMetric(
|
|
durationDesc,
|
|
prometheus.GaugeValue,
|
|
duration,
|
|
)
|
|
}()
|
|
|
|
config := c.config.ConfigForTarget(c.target, c.module)
|
|
target := ipmiTarget{
|
|
host: c.target,
|
|
config: config,
|
|
}
|
|
|
|
for _, collector := range config.GetCollectors() {
|
|
var up int
|
|
log.Debugf("Running collector: %s", collector.Name())
|
|
|
|
fqcmd := path.Join(*executablesPath, collector.Cmd())
|
|
args := collector.Args()
|
|
cfg := config.GetFreeipmiConfig()
|
|
|
|
result := freeipmi.Execute(fqcmd, args, cfg, target.host, log.Base())
|
|
|
|
up, _ = collector.Collect(result, ch, target)
|
|
markCollectorUp(ch, string(collector.Name()), up)
|
|
}
|
|
}
|
|
|
|
func targetName(target string) string {
|
|
if target == targetLocal {
|
|
return "[local]"
|
|
}
|
|
return target
|
|
}
|