Merge pull request #75 from prometheus/remove-attribute-module
Use flags instead of config and remove attributespull/78/head
commit
b539481503
|
@ -31,7 +31,6 @@ Which collectors are used is controlled by the `--collectors.enabled` flag.
|
||||||
|
|
||||||
Name | Description
|
Name | Description
|
||||||
---------|------------
|
---------|------------
|
||||||
attributes | Exposes attributes from the configuration file. Deprecated, use textfile module instead.
|
|
||||||
diskstats | Exposes disk I/O statistics from `/proc/diskstats`.
|
diskstats | Exposes disk I/O statistics from `/proc/diskstats`.
|
||||||
filesystem | Exposes filesystem statistics, such as disk space used.
|
filesystem | Exposes filesystem statistics, such as disk space used.
|
||||||
loadavg | Exposes load average.
|
loadavg | Exposes load average.
|
||||||
|
|
|
@ -1,46 +0,0 @@
|
||||||
// +build !noattributes
|
|
||||||
|
|
||||||
package collector
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/golang/glog"
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
|
||||||
)
|
|
||||||
|
|
||||||
type attributesCollector struct {
|
|
||||||
config Config
|
|
||||||
metric *prometheus.GaugeVec
|
|
||||||
}
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
Factories["attributes"] = NewAttributesCollector
|
|
||||||
}
|
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
|
||||||
// labels from the config.
|
|
||||||
func NewAttributesCollector(config Config) (Collector, error) {
|
|
||||||
labelNames := []string{}
|
|
||||||
for l := range config.Attributes {
|
|
||||||
labelNames = append(labelNames, l)
|
|
||||||
}
|
|
||||||
|
|
||||||
return &attributesCollector{
|
|
||||||
config: config,
|
|
||||||
metric: prometheus.NewGaugeVec(
|
|
||||||
prometheus.GaugeOpts{
|
|
||||||
Namespace: Namespace,
|
|
||||||
Name: "attributes",
|
|
||||||
Help: "The node_exporter attributes.",
|
|
||||||
},
|
|
||||||
labelNames,
|
|
||||||
),
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *attributesCollector) Update(ch chan<- prometheus.Metric) (err error) {
|
|
||||||
glog.V(1).Info("Set node_attributes{%v}: 1", c.config.Attributes)
|
|
||||||
c.metric.Reset()
|
|
||||||
c.metric.With(c.config.Attributes).Set(1)
|
|
||||||
c.metric.Collect(ch)
|
|
||||||
return err
|
|
||||||
}
|
|
|
@ -26,7 +26,7 @@ func init() {
|
||||||
|
|
||||||
// NewBondingCollector returns a newly allocated bondingCollector.
|
// NewBondingCollector returns a newly allocated bondingCollector.
|
||||||
// It exposes the number of configured and active slave of linux bonding interfaces.
|
// It exposes the number of configured and active slave of linux bonding interfaces.
|
||||||
func NewBondingCollector(config Config) (Collector, error) {
|
func NewBondingCollector() (Collector, error) {
|
||||||
return &bondingCollector{
|
return &bondingCollector{
|
||||||
slaves: prometheus.NewGaugeVec(
|
slaves: prometheus.NewGaugeVec(
|
||||||
prometheus.GaugeOpts{
|
prometheus.GaugeOpts{
|
||||||
|
|
|
@ -7,7 +7,7 @@ import (
|
||||||
|
|
||||||
const Namespace = "node"
|
const Namespace = "node"
|
||||||
|
|
||||||
var Factories = make(map[string]func(Config) (Collector, error))
|
var Factories = make(map[string]func() (Collector, error))
|
||||||
|
|
||||||
// Interface a collector has to implement.
|
// Interface a collector has to implement.
|
||||||
type Collector interface {
|
type Collector interface {
|
||||||
|
@ -20,8 +20,3 @@ type Collector interface {
|
||||||
// scraped. (However, for metric gathering that takes very long, it might
|
// scraped. (However, for metric gathering that takes very long, it might
|
||||||
// actually be better to do them proactively before scraping to minimize scrape
|
// actually be better to do them proactively before scraping to minimize scrape
|
||||||
// time.)
|
// time.)
|
||||||
|
|
||||||
type Config struct {
|
|
||||||
Config map[string]string `json:"config"`
|
|
||||||
Attributes map[string]string `json:"attributes"`
|
|
||||||
}
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
type diskstatsCollector struct {
|
type diskstatsCollector struct {
|
||||||
config Config
|
|
||||||
ignoredDevicesPattern *regexp.Regexp
|
ignoredDevicesPattern *regexp.Regexp
|
||||||
metrics []prometheus.Collector
|
metrics []prometheus.Collector
|
||||||
}
|
}
|
||||||
|
@ -35,13 +35,12 @@ func init() {
|
||||||
Factories["diskstats"] = NewDiskstatsCollector
|
Factories["diskstats"] = NewDiskstatsCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// disk device stats.
|
// disk device stats.
|
||||||
func NewDiskstatsCollector(config Config) (Collector, error) {
|
func NewDiskstatsCollector() (Collector, error) {
|
||||||
var diskLabelNames = []string{"device"}
|
var diskLabelNames = []string{"device"}
|
||||||
|
|
||||||
return &diskstatsCollector{
|
return &diskstatsCollector{
|
||||||
config: config,
|
|
||||||
ignoredDevicesPattern: regexp.MustCompile(*ignoredDevices),
|
ignoredDevicesPattern: regexp.MustCompile(*ignoredDevices),
|
||||||
// Docs from https://www.kernel.org/doc/Documentation/iostats.txt
|
// Docs from https://www.kernel.org/doc/Documentation/iostats.txt
|
||||||
metrics: []prometheus.Collector{
|
metrics: []prometheus.Collector{
|
||||||
|
|
|
@ -25,7 +25,7 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
type filesystemCollector struct {
|
type filesystemCollector struct {
|
||||||
config Config
|
|
||||||
ignoredMountPointsPattern *regexp.Regexp
|
ignoredMountPointsPattern *regexp.Regexp
|
||||||
|
|
||||||
size, free, avail, files, filesFree *prometheus.GaugeVec
|
size, free, avail, files, filesFree *prometheus.GaugeVec
|
||||||
|
@ -35,13 +35,13 @@ func init() {
|
||||||
Factories["filesystem"] = NewFilesystemCollector
|
Factories["filesystem"] = NewFilesystemCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// network device filesystems.
|
// network device filesystems.
|
||||||
func NewFilesystemCollector(config Config) (Collector, error) {
|
func NewFilesystemCollector() (Collector, error) {
|
||||||
var filesystemLabelNames = []string{"filesystem"}
|
var filesystemLabelNames = []string{"filesystem"}
|
||||||
|
|
||||||
return &filesystemCollector{
|
return &filesystemCollector{
|
||||||
config: config,
|
|
||||||
ignoredMountPointsPattern: regexp.MustCompile(*ignoredMountPoints),
|
ignoredMountPointsPattern: regexp.MustCompile(*ignoredMountPoints),
|
||||||
size: prometheus.NewGaugeVec(
|
size: prometheus.NewGaugeVec(
|
||||||
prometheus.GaugeOpts{
|
prometheus.GaugeOpts{
|
||||||
|
|
|
@ -25,7 +25,7 @@ const (
|
||||||
|
|
||||||
type gmondCollector struct {
|
type gmondCollector struct {
|
||||||
metrics map[string]*prometheus.GaugeVec
|
metrics map[string]*prometheus.GaugeVec
|
||||||
config Config
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
|
@ -34,10 +34,9 @@ func init() {
|
||||||
|
|
||||||
var illegalCharsRE = regexp.MustCompile(`[^a-zA-Z0-9_]`)
|
var illegalCharsRE = regexp.MustCompile(`[^a-zA-Z0-9_]`)
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector scraping ganglia.
|
// Takes a prometheus registry and returns a new Collector scraping ganglia.
|
||||||
func NewGmondCollector(config Config) (Collector, error) {
|
func NewGmondCollector() (Collector, error) {
|
||||||
c := gmondCollector{
|
c := gmondCollector{
|
||||||
config: config,
|
|
||||||
metrics: map[string]*prometheus.GaugeVec{},
|
metrics: map[string]*prometheus.GaugeVec{},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type interruptsCollector struct {
|
type interruptsCollector struct {
|
||||||
config Config
|
|
||||||
metric *prometheus.CounterVec
|
metric *prometheus.CounterVec
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -26,11 +26,11 @@ func init() {
|
||||||
Factories["interrupts"] = NewInterruptsCollector
|
Factories["interrupts"] = NewInterruptsCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// interrupts stats
|
// interrupts stats
|
||||||
func NewInterruptsCollector(config Config) (Collector, error) {
|
func NewInterruptsCollector() (Collector, error) {
|
||||||
return &interruptsCollector{
|
return &interruptsCollector{
|
||||||
config: config,
|
|
||||||
metric: prometheus.NewCounterVec(
|
metric: prometheus.NewCounterVec(
|
||||||
prometheus.CounterOpts{
|
prometheus.CounterOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
package collector
|
package collector
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
|
@ -10,6 +11,10 @@ import (
|
||||||
"github.com/prometheus/procfs"
|
"github.com/prometheus/procfs"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
ipvsProcfsMountPoint = flag.String("collector.ipvs.procfs", procfs.DefaultMountPoint, "procfs mountpoint.")
|
||||||
|
)
|
||||||
|
|
||||||
type ipvsCollector struct {
|
type ipvsCollector struct {
|
||||||
Collector
|
Collector
|
||||||
fs procfs.FS
|
fs procfs.FS
|
||||||
|
@ -23,11 +28,11 @@ func init() {
|
||||||
|
|
||||||
// NewIPVSCollector sets up a new collector for IPVS metrics. It accepts the
|
// NewIPVSCollector sets up a new collector for IPVS metrics. It accepts the
|
||||||
// "procfs" config parameter to override the default proc location (/proc).
|
// "procfs" config parameter to override the default proc location (/proc).
|
||||||
func NewIPVSCollector(config Config) (Collector, error) {
|
func NewIPVSCollector() (Collector, error) {
|
||||||
return newIPVSCollector(config)
|
return newIPVSCollector()
|
||||||
}
|
}
|
||||||
|
|
||||||
func newIPVSCollector(config Config) (*ipvsCollector, error) {
|
func newIPVSCollector() (*ipvsCollector, error) {
|
||||||
var (
|
var (
|
||||||
ipvsBackendLabelNames = []string{
|
ipvsBackendLabelNames = []string{
|
||||||
"local_address",
|
"local_address",
|
||||||
|
@ -37,23 +42,14 @@ func newIPVSCollector(config Config) (*ipvsCollector, error) {
|
||||||
"proto",
|
"proto",
|
||||||
}
|
}
|
||||||
c ipvsCollector
|
c ipvsCollector
|
||||||
subsystem string
|
|
||||||
err error
|
err error
|
||||||
|
subsystem = "ipvs"
|
||||||
)
|
)
|
||||||
|
|
||||||
if p, ok := config.Config["procfs"]; !ok {
|
c.fs, err = procfs.NewFS(*ipvsProcfsMountPoint)
|
||||||
c.fs, err = procfs.NewFS(procfs.DefaultMountPoint)
|
|
||||||
} else {
|
|
||||||
c.fs, err = procfs.NewFS(p)
|
|
||||||
}
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if s, ok := config.Config["ipvs_subsystem"]; ok {
|
|
||||||
subsystem = s
|
|
||||||
} else {
|
|
||||||
subsystem = "ipvs"
|
|
||||||
}
|
|
||||||
|
|
||||||
c.connections = prometheus.NewCounter(
|
c.connections = prometheus.NewCounter(
|
||||||
prometheus.CounterOpts{
|
prometheus.CounterOpts{
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package collector
|
package collector
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"flag"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
@ -106,7 +107,10 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestIPVSCollector(t *testing.T) {
|
func TestIPVSCollector(t *testing.T) {
|
||||||
collector, err := newIPVSCollector(Config{Config: map[string]string{"procfs": "fixtures"}})
|
if err := flag.Set("collector.ipvs.procfs", "fixtures"); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
collector, err := newIPVSCollector()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -165,7 +169,10 @@ func (c miniCollector) Describe(ch chan<- *prometheus.Desc) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestIPVSCollectorResponse(t *testing.T) {
|
func TestIPVSCollectorResponse(t *testing.T) {
|
||||||
collector, err := NewIPVSCollector(Config{Config: map[string]string{"procfs": "fixtures"}})
|
if err := flag.Set("collector.ipvs.procfs", "fixtures"); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
collector, err := NewIPVSCollector()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
@ -183,6 +190,7 @@ func TestIPVSCollectorResponse(t *testing.T) {
|
||||||
wantLines := strings.Split(string(wantMetrics), "\n")
|
wantLines := strings.Split(string(wantMetrics), "\n")
|
||||||
gotLines := strings.Split(string(rw.Body.String()), "\n")
|
gotLines := strings.Split(string(rw.Body.String()), "\n")
|
||||||
gotLinesIdx := 0
|
gotLinesIdx := 0
|
||||||
|
t.Log(gotLines)
|
||||||
|
|
||||||
// Until the Prometheus Go client library offers better testability
|
// Until the Prometheus Go client library offers better testability
|
||||||
// (https://github.com/prometheus/client_golang/issues/58), we simply compare
|
// (https://github.com/prometheus/client_golang/issues/58), we simply compare
|
||||||
|
|
|
@ -17,7 +17,7 @@ import (
|
||||||
const lastLoginSubsystem = "last_login"
|
const lastLoginSubsystem = "last_login"
|
||||||
|
|
||||||
type lastLoginCollector struct {
|
type lastLoginCollector struct {
|
||||||
config Config
|
|
||||||
metric prometheus.Gauge
|
metric prometheus.Gauge
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,11 +25,11 @@ func init() {
|
||||||
Factories["lastlogin"] = NewLastLoginCollector
|
Factories["lastlogin"] = NewLastLoginCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// load, seconds since last login and a list of tags as specified by config.
|
// load, seconds since last login and a list of tags as specified by config.
|
||||||
func NewLastLoginCollector(config Config) (Collector, error) {
|
func NewLastLoginCollector() (Collector, error) {
|
||||||
return &lastLoginCollector{
|
return &lastLoginCollector{
|
||||||
config: config,
|
|
||||||
metric: prometheus.NewGauge(prometheus.GaugeOpts{
|
metric: prometheus.NewGauge(prometheus.GaugeOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
Subsystem: lastLoginSubsystem,
|
Subsystem: lastLoginSubsystem,
|
||||||
|
|
|
@ -17,7 +17,7 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type loadavgCollector struct {
|
type loadavgCollector struct {
|
||||||
config Config
|
|
||||||
metric prometheus.Gauge
|
metric prometheus.Gauge
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,11 +25,11 @@ func init() {
|
||||||
Factories["loadavg"] = NewLoadavgCollector
|
Factories["loadavg"] = NewLoadavgCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// load, seconds since last login and a list of tags as specified by config.
|
// load, seconds since last login and a list of tags as specified by config.
|
||||||
func NewLoadavgCollector(config Config) (Collector, error) {
|
func NewLoadavgCollector() (Collector, error) {
|
||||||
return &loadavgCollector{
|
return &loadavgCollector{
|
||||||
config: config,
|
|
||||||
metric: prometheus.NewGauge(prometheus.GaugeOpts{
|
metric: prometheus.NewGauge(prometheus.GaugeOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
Name: "load1",
|
Name: "load1",
|
||||||
|
|
|
@ -4,6 +4,7 @@ package collector
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
|
"flag"
|
||||||
"io"
|
"io"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"strconv"
|
"strconv"
|
||||||
|
@ -17,9 +18,12 @@ const (
|
||||||
adapterHeaderSep = "================"
|
adapterHeaderSep = "================"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
megacliCommand = flag.String("collector.megacli.command", defaultMegaCli, "Command to run megacli.")
|
||||||
|
)
|
||||||
|
|
||||||
type megaCliCollector struct {
|
type megaCliCollector struct {
|
||||||
config Config
|
cli string
|
||||||
cli string
|
|
||||||
|
|
||||||
driveTemperature *prometheus.GaugeVec
|
driveTemperature *prometheus.GaugeVec
|
||||||
driveCounters *prometheus.CounterVec
|
driveCounters *prometheus.CounterVec
|
||||||
|
@ -30,17 +34,12 @@ func init() {
|
||||||
Factories["megacli"] = NewMegaCliCollector
|
Factories["megacli"] = NewMegaCliCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// RAID status through megacli.
|
// RAID status through megacli.
|
||||||
func NewMegaCliCollector(config Config) (Collector, error) {
|
func NewMegaCliCollector() (Collector, error) {
|
||||||
cli := defaultMegaCli
|
|
||||||
if config.Config["megacli_command"] != "" {
|
|
||||||
cli = config.Config["megacli_command"]
|
|
||||||
}
|
|
||||||
|
|
||||||
return &megaCliCollector{
|
return &megaCliCollector{
|
||||||
config: config,
|
|
||||||
cli: cli,
|
cli: *megacliCommand,
|
||||||
driveTemperature: prometheus.NewGaugeVec(prometheus.GaugeOpts{
|
driveTemperature: prometheus.NewGaugeVec(prometheus.GaugeOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
Name: "megacli_drive_temperature_celsius",
|
Name: "megacli_drive_temperature_celsius",
|
||||||
|
|
|
@ -21,7 +21,7 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type meminfoCollector struct {
|
type meminfoCollector struct {
|
||||||
config Config
|
|
||||||
metrics map[string]prometheus.Gauge
|
metrics map[string]prometheus.Gauge
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,11 +29,10 @@ func init() {
|
||||||
Factories["meminfo"] = NewMeminfoCollector
|
Factories["meminfo"] = NewMeminfoCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// memory stats.
|
// memory stats.
|
||||||
func NewMeminfoCollector(config Config) (Collector, error) {
|
func NewMeminfoCollector() (Collector, error) {
|
||||||
return &meminfoCollector{
|
return &meminfoCollector{
|
||||||
config: config,
|
|
||||||
metrics: map[string]prometheus.Gauge{},
|
metrics: map[string]prometheus.Gauge{},
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ var (
|
||||||
)
|
)
|
||||||
|
|
||||||
type netDevCollector struct {
|
type netDevCollector struct {
|
||||||
config Config
|
|
||||||
metrics map[string]*prometheus.GaugeVec
|
metrics map[string]*prometheus.GaugeVec
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -32,11 +32,10 @@ func init() {
|
||||||
Factories["netdev"] = NewNetDevCollector
|
Factories["netdev"] = NewNetDevCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// network device stats.
|
// network device stats.
|
||||||
func NewNetDevCollector(config Config) (Collector, error) {
|
func NewNetDevCollector() (Collector, error) {
|
||||||
return &netDevCollector{
|
return &netDevCollector{
|
||||||
config: config,
|
|
||||||
metrics: map[string]*prometheus.GaugeVec{},
|
metrics: map[string]*prometheus.GaugeVec{},
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type netStatCollector struct {
|
type netStatCollector struct {
|
||||||
config Config
|
|
||||||
metrics map[string]prometheus.Gauge
|
metrics map[string]prometheus.Gauge
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,11 +27,10 @@ func init() {
|
||||||
Factories["netstat"] = NewNetStatCollector
|
Factories["netstat"] = NewNetStatCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewNetStatCollector takes a config struct and returns
|
// NewNetStatCollector takes a returns
|
||||||
// a new Collector exposing network stats.
|
// a new Collector exposing network stats.
|
||||||
func NewNetStatCollector(config Config) (Collector, error) {
|
func NewNetStatCollector() (Collector, error) {
|
||||||
return &netStatCollector{
|
return &netStatCollector{
|
||||||
config: config,
|
|
||||||
metrics: map[string]prometheus.Gauge{},
|
metrics: map[string]prometheus.Gauge{},
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,9 +24,9 @@ func init() {
|
||||||
Factories["ntp"] = NewNtpCollector
|
Factories["ntp"] = NewNtpCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// the offset between ntp and the current system time.
|
// the offset between ntp and the current system time.
|
||||||
func NewNtpCollector(config Config) (Collector, error) {
|
func NewNtpCollector() (Collector, error) {
|
||||||
if *ntpServer == "" {
|
if *ntpServer == "" {
|
||||||
return nil, fmt.Errorf("No NTP server specifies, see --ntpServer")
|
return nil, fmt.Errorf("No NTP server specifies, see --ntpServer")
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type runitCollector struct {
|
type runitCollector struct {
|
||||||
config Config
|
|
||||||
|
|
||||||
state, stateDesired, stateNormal *prometheus.GaugeVec
|
state, stateDesired, stateNormal *prometheus.GaugeVec
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ func init() {
|
||||||
Factories["runit"] = NewRunitCollector
|
Factories["runit"] = NewRunitCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewRunitCollector(config Config) (Collector, error) {
|
func NewRunitCollector() (Collector, error) {
|
||||||
var (
|
var (
|
||||||
subsystem = "service"
|
subsystem = "service"
|
||||||
constLabels = prometheus.Labels{"supervisor": "runit"}
|
constLabels = prometheus.Labels{"supervisor": "runit"}
|
||||||
|
@ -26,7 +26,7 @@ func NewRunitCollector(config Config) (Collector, error) {
|
||||||
)
|
)
|
||||||
|
|
||||||
return &runitCollector{
|
return &runitCollector{
|
||||||
config: config,
|
|
||||||
state: prometheus.NewGaugeVec(
|
state: prometheus.NewGaugeVec(
|
||||||
prometheus.GaugeOpts{
|
prometheus.GaugeOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
|
|
|
@ -17,7 +17,7 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type statCollector struct {
|
type statCollector struct {
|
||||||
config Config
|
|
||||||
cpu *prometheus.CounterVec
|
cpu *prometheus.CounterVec
|
||||||
intr prometheus.Counter
|
intr prometheus.Counter
|
||||||
ctxt prometheus.Counter
|
ctxt prometheus.Counter
|
||||||
|
@ -31,11 +31,11 @@ func init() {
|
||||||
Factories["stat"] = NewStatCollector
|
Factories["stat"] = NewStatCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// network device stats.
|
// network device stats.
|
||||||
func NewStatCollector(config Config) (Collector, error) {
|
func NewStatCollector() (Collector, error) {
|
||||||
return &statCollector{
|
return &statCollector{
|
||||||
config: config,
|
|
||||||
cpu: prometheus.NewCounterVec(
|
cpu: prometheus.NewCounterVec(
|
||||||
prometheus.CounterOpts{
|
prometheus.CounterOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
|
|
|
@ -35,7 +35,7 @@ const (
|
||||||
)
|
)
|
||||||
|
|
||||||
type tcpStatCollector struct {
|
type tcpStatCollector struct {
|
||||||
config Config
|
|
||||||
metric *prometheus.GaugeVec
|
metric *prometheus.GaugeVec
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,11 +43,11 @@ func init() {
|
||||||
Factories["tcpstat"] = NewTCPStatCollector
|
Factories["tcpstat"] = NewTCPStatCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewTCPStatCollector takes a config struct and returns
|
// NewTCPStatCollector takes a returns
|
||||||
// a new Collector exposing network stats.
|
// a new Collector exposing network stats.
|
||||||
func NewTCPStatCollector(config Config) (Collector, error) {
|
func NewTCPStatCollector() (Collector, error) {
|
||||||
return &tcpStatCollector{
|
return &tcpStatCollector{
|
||||||
config: config,
|
|
||||||
metric: prometheus.NewGaugeVec(
|
metric: prometheus.NewGaugeVec(
|
||||||
prometheus.GaugeOpts{
|
prometheus.GaugeOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
|
|
|
@ -31,9 +31,9 @@ func init() {
|
||||||
Factories["textfile"] = NewTextFileCollector
|
Factories["textfile"] = NewTextFileCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and registers a
|
// Takes a registers a
|
||||||
// SetMetricFamilyInjectionHook.
|
// SetMetricFamilyInjectionHook.
|
||||||
func NewTextFileCollector(config Config) (Collector, error) {
|
func NewTextFileCollector() (Collector, error) {
|
||||||
if *textFileDirectory == "" {
|
if *textFileDirectory == "" {
|
||||||
// This collector is enabled by default, so do not fail if
|
// This collector is enabled by default, so do not fail if
|
||||||
// the flag is not passed.
|
// the flag is not passed.
|
||||||
|
|
|
@ -10,7 +10,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type timeCollector struct {
|
type timeCollector struct {
|
||||||
config Config
|
|
||||||
metric prometheus.Counter
|
metric prometheus.Counter
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,11 +18,11 @@ func init() {
|
||||||
Factories["time"] = NewTimeCollector
|
Factories["time"] = NewTimeCollector
|
||||||
}
|
}
|
||||||
|
|
||||||
// Takes a config struct and prometheus registry and returns a new Collector exposing
|
// Takes a prometheus registry and returns a new Collector exposing
|
||||||
// the current system time in seconds since epoch.
|
// the current system time in seconds since epoch.
|
||||||
func NewTimeCollector(config Config) (Collector, error) {
|
func NewTimeCollector() (Collector, error) {
|
||||||
return &timeCollector{
|
return &timeCollector{
|
||||||
config: config,
|
|
||||||
metric: prometheus.NewCounter(prometheus.CounterOpts{
|
metric: prometheus.NewCounter(prometheus.CounterOpts{
|
||||||
Namespace: Namespace,
|
Namespace: Namespace,
|
||||||
Name: "time",
|
Name: "time",
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
_ "net/http/pprof"
|
_ "net/http/pprof"
|
||||||
"os"
|
"os"
|
||||||
|
@ -26,11 +24,10 @@ var (
|
||||||
// set at build time
|
// set at build time
|
||||||
Version = "0.0.0.dev"
|
Version = "0.0.0.dev"
|
||||||
|
|
||||||
configFile = flag.String("config.file", "", "Path to config file.")
|
|
||||||
memProfile = flag.String("debug.memprofile-file", "", "Write memory profile to this file upon receipt of SIGUSR1.")
|
memProfile = flag.String("debug.memprofile-file", "", "Write memory profile to this file upon receipt of SIGUSR1.")
|
||||||
listenAddress = flag.String("web.listen-address", ":9100", "Address on which to expose metrics and web interface.")
|
listenAddress = flag.String("web.listen-address", ":9100", "Address on which to expose metrics and web interface.")
|
||||||
metricsPath = flag.String("web.telemetry-path", "/metrics", "Path under which to expose metrics.")
|
metricsPath = flag.String("web.telemetry-path", "/metrics", "Path under which to expose metrics.")
|
||||||
enabledCollectors = flag.String("collectors.enabled", "attributes,diskstats,filesystem,loadavg,meminfo,stat,textfile,time,netdev,netstat", "Comma-separated list of collectors to use.")
|
enabledCollectors = flag.String("collectors.enabled", "diskstats,filesystem,loadavg,meminfo,stat,textfile,time,netdev,netstat", "Comma-separated list of collectors to use.")
|
||||||
printCollectors = flag.Bool("collectors.print", false, "If true, print available collectors and exit.")
|
printCollectors = flag.Bool("collectors.print", false, "If true, print available collectors and exit.")
|
||||||
authUser = flag.String("auth.user", "", "Username for basic auth.")
|
authUser = flag.String("auth.user", "", "Username for basic auth.")
|
||||||
authPass = flag.String("auth.pass", "", "Password for basic auth.")
|
authPass = flag.String("auth.pass", "", "Password for basic auth.")
|
||||||
|
@ -105,32 +102,14 @@ func Execute(name string, c collector.Collector, ch chan<- prometheus.Metric) {
|
||||||
scrapeDurations.WithLabelValues(name, result).Observe(duration.Seconds())
|
scrapeDurations.WithLabelValues(name, result).Observe(duration.Seconds())
|
||||||
}
|
}
|
||||||
|
|
||||||
func getConfig(file string) (*collector.Config, error) {
|
func loadCollectors() (map[string]collector.Collector, error) {
|
||||||
config := &collector.Config{}
|
|
||||||
glog.Infof("Reading config %s", *configFile)
|
|
||||||
bytes, err := ioutil.ReadFile(*configFile)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return config, json.Unmarshal(bytes, &config)
|
|
||||||
}
|
|
||||||
|
|
||||||
func loadCollectors(file string) (map[string]collector.Collector, error) {
|
|
||||||
collectors := map[string]collector.Collector{}
|
collectors := map[string]collector.Collector{}
|
||||||
config := &collector.Config{}
|
|
||||||
if file != "" {
|
|
||||||
var err error
|
|
||||||
config, err = getConfig(file)
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("couldn't read config %s: %s", file, err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for _, name := range strings.Split(*enabledCollectors, ",") {
|
for _, name := range strings.Split(*enabledCollectors, ",") {
|
||||||
fn, ok := collector.Factories[name]
|
fn, ok := collector.Factories[name]
|
||||||
if !ok {
|
if !ok {
|
||||||
return nil, fmt.Errorf("collector '%s' not available", name)
|
return nil, fmt.Errorf("collector '%s' not available", name)
|
||||||
}
|
}
|
||||||
c, err := fn(*config)
|
c, err := fn()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -154,9 +133,9 @@ func main() {
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
collectors, err := loadCollectors(*configFile)
|
collectors, err := loadCollectors()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
glog.Fatalf("Couldn't load config and collectors: %s", err)
|
glog.Fatalf("Couldn't load collectors: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
glog.Infof("Enabled collectors:")
|
glog.Infof("Enabled collectors:")
|
||||||
|
|
Loading…
Reference in New Issue