Merge pull request #79 from prometheus/migrate-logging

Switch logging from glog to github.com/prometheus/log
This commit is contained in:
Julius Volz 2015-05-28 21:58:02 +02:00
commit 94d225919b
19 changed files with 37 additions and 65 deletions

View File

@ -2,5 +2,4 @@ FROM golang:onbuild
MAINTAINER Prometheus Team <prometheus-developers@googlegroups.com> MAINTAINER Prometheus Team <prometheus-developers@googlegroups.com>
ENTRYPOINT [ "go-wrapper", "run" ] ENTRYPOINT [ "go-wrapper", "run" ]
CMD [ "-logtostderr" ]
EXPOSE 9100 EXPOSE 9100

View File

@ -10,12 +10,6 @@ collectors.
make make
./node_exporter <flags> ./node_exporter <flags>
The node_exporter uses the [glog][glog] library for logging. With the default
parameters, nothing will be logged. Use `-logtostderr` to enable logging to
stderr and `--help` to see more options about logging.
[glog]: https://godoc.org/github.com/golang/glog
## Running tests ## Running tests
make test make test

View File

@ -12,8 +12,8 @@ import (
"strconv" "strconv"
"strings" "strings"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
) )
const ( const (
@ -26,7 +26,6 @@ var (
) )
type diskstatsCollector struct { type diskstatsCollector struct {
ignoredDevicesPattern *regexp.Regexp ignoredDevicesPattern *regexp.Regexp
metrics []prometheus.Collector metrics []prometheus.Collector
} }
@ -155,7 +154,7 @@ func (c *diskstatsCollector) Update(ch chan<- prometheus.Metric) (err error) {
for dev, stats := range diskStats { for dev, stats := range diskStats {
if c.ignoredDevicesPattern.MatchString(dev) { if c.ignoredDevicesPattern.MatchString(dev) {
glog.V(1).Infof("Ignoring device: %s", dev) log.Debugf("Ignoring device: %s", dev)
continue continue
} }

View File

@ -11,8 +11,8 @@ import (
"strings" "strings"
"syscall" "syscall"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
) )
const ( const (
@ -25,7 +25,6 @@ var (
) )
type filesystemCollector struct { type filesystemCollector struct {
ignoredMountPointsPattern *regexp.Regexp ignoredMountPointsPattern *regexp.Regexp
size, free, avail, files, filesFree *prometheus.GaugeVec size, free, avail, files, filesFree *prometheus.GaugeVec
@ -41,7 +40,6 @@ func NewFilesystemCollector() (Collector, error) {
var filesystemLabelNames = []string{"filesystem"} var filesystemLabelNames = []string{"filesystem"}
return &filesystemCollector{ return &filesystemCollector{
ignoredMountPointsPattern: regexp.MustCompile(*ignoredMountPoints), ignoredMountPointsPattern: regexp.MustCompile(*ignoredMountPoints),
size: prometheus.NewGaugeVec( size: prometheus.NewGaugeVec(
prometheus.GaugeOpts{ prometheus.GaugeOpts{
@ -99,7 +97,7 @@ func (c *filesystemCollector) Update(ch chan<- prometheus.Metric) (err error) {
} }
for _, mp := range mps { for _, mp := range mps {
if c.ignoredMountPointsPattern.MatchString(mp) { if c.ignoredMountPointsPattern.MatchString(mp) {
glog.V(1).Infof("Ignoring mount point: %s", mp) log.Debugf("Ignoring mount point: %s", mp)
continue continue
} }
buf := new(syscall.Statfs_t) buf := new(syscall.Statfs_t)

View File

@ -11,8 +11,9 @@ import (
"regexp" "regexp"
"time" "time"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
"github.com/prometheus/node_exporter/collector/ganglia" "github.com/prometheus/node_exporter/collector/ganglia"
) )
@ -25,7 +26,6 @@ const (
type gmondCollector struct { type gmondCollector struct {
metrics map[string]*prometheus.GaugeVec metrics map[string]*prometheus.GaugeVec
} }
func init() { func init() {
@ -45,7 +45,7 @@ func NewGmondCollector() (Collector, error) {
func (c *gmondCollector) Update(ch chan<- prometheus.Metric) (err error) { func (c *gmondCollector) Update(ch chan<- prometheus.Metric) (err error) {
conn, err := net.Dial(gangliaProto, gangliaAddress) conn, err := net.Dial(gangliaProto, gangliaAddress)
glog.V(1).Infof("gmondCollector Update") log.Debugf("gmondCollector Update")
if err != nil { if err != nil {
return fmt.Errorf("Can't connect to gmond: %s", err) return fmt.Errorf("Can't connect to gmond: %s", err)
} }
@ -91,7 +91,7 @@ func (c *gmondCollector) setMetric(name, cluster string, metric ganglia.Metric)
break break
} }
} }
glog.V(1).Infof("Register %s: %s", name, desc) log.Debugf("Register %s: %s", name, desc)
c.metrics[name] = prometheus.NewGaugeVec( c.metrics[name] = prometheus.NewGaugeVec(
prometheus.GaugeOpts{ prometheus.GaugeOpts{
Namespace: gangliaNamespace, Namespace: gangliaNamespace,
@ -101,7 +101,7 @@ func (c *gmondCollector) setMetric(name, cluster string, metric ganglia.Metric)
[]string{"cluster"}, []string{"cluster"},
) )
} }
glog.V(1).Infof("Set %s{cluster=%q}: %f", name, cluster, metric.Value) log.Debugf("Set %s{cluster=%q}: %f", name, cluster, metric.Value)
c.metrics[name].WithLabelValues(cluster).Set(metric.Value) c.metrics[name].WithLabelValues(cluster).Set(metric.Value)
} }

View File

@ -18,7 +18,6 @@ const (
) )
type interruptsCollector struct { type interruptsCollector struct {
metric *prometheus.CounterVec metric *prometheus.CounterVec
} }
@ -30,7 +29,6 @@ func init() {
// interrupts stats // interrupts stats
func NewInterruptsCollector() (Collector, error) { func NewInterruptsCollector() (Collector, error) {
return &interruptsCollector{ return &interruptsCollector{
metric: prometheus.NewCounterVec( metric: prometheus.NewCounterVec(
prometheus.CounterOpts{ prometheus.CounterOpts{
Namespace: Namespace, Namespace: Namespace,

View File

@ -10,14 +10,13 @@ import (
"strings" "strings"
"time" "time"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
) )
const lastLoginSubsystem = "last_login" const lastLoginSubsystem = "last_login"
type lastLoginCollector struct { type lastLoginCollector struct {
metric prometheus.Gauge metric prometheus.Gauge
} }
@ -29,7 +28,6 @@ func init() {
// 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() (Collector, error) { func NewLastLoginCollector() (Collector, error) {
return &lastLoginCollector{ return &lastLoginCollector{
metric: prometheus.NewGauge(prometheus.GaugeOpts{ metric: prometheus.NewGauge(prometheus.GaugeOpts{
Namespace: Namespace, Namespace: Namespace,
Subsystem: lastLoginSubsystem, Subsystem: lastLoginSubsystem,
@ -44,7 +42,7 @@ func (c *lastLoginCollector) Update(ch chan<- prometheus.Metric) (err error) {
if err != nil { if err != nil {
return fmt.Errorf("Couldn't get last seen: %s", err) return fmt.Errorf("Couldn't get last seen: %s", err)
} }
glog.V(1).Infof("Set node_last_login_time: %f", last) log.Debugf("Set node_last_login_time: %f", last)
c.metric.Set(last) c.metric.Set(last)
c.metric.Collect(ch) c.metric.Collect(ch)
return err return err

View File

@ -8,8 +8,8 @@ import (
"strconv" "strconv"
"strings" "strings"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
) )
const ( const (
@ -17,7 +17,6 @@ const (
) )
type loadavgCollector struct { type loadavgCollector struct {
metric prometheus.Gauge metric prometheus.Gauge
} }
@ -29,7 +28,6 @@ func init() {
// 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() (Collector, error) { func NewLoadavgCollector() (Collector, error) {
return &loadavgCollector{ return &loadavgCollector{
metric: prometheus.NewGauge(prometheus.GaugeOpts{ metric: prometheus.NewGauge(prometheus.GaugeOpts{
Namespace: Namespace, Namespace: Namespace,
Name: "load1", Name: "load1",
@ -43,7 +41,7 @@ func (c *loadavgCollector) Update(ch chan<- prometheus.Metric) (err error) {
if err != nil { if err != nil {
return fmt.Errorf("Couldn't get load: %s", err) return fmt.Errorf("Couldn't get load: %s", err)
} }
glog.V(1).Infof("Set node_load: %f", load) log.Debugf("Set node_load: %f", load)
c.metric.Set(load) c.metric.Set(load)
c.metric.Collect(ch) c.metric.Collect(ch)
return err return err

View File

@ -38,8 +38,7 @@ func init() {
// RAID status through megacli. // RAID status through megacli.
func NewMegaCliCollector() (Collector, error) { func NewMegaCliCollector() (Collector, error) {
return &megaCliCollector{ return &megaCliCollector{
cli: *megacliCommand,
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",

View File

@ -11,8 +11,8 @@ import (
"strconv" "strconv"
"strings" "strings"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
) )
const ( const (
@ -21,7 +21,6 @@ const (
) )
type meminfoCollector struct { type meminfoCollector struct {
metrics map[string]prometheus.Gauge metrics map[string]prometheus.Gauge
} }
@ -42,7 +41,7 @@ func (c *meminfoCollector) Update(ch chan<- prometheus.Metric) (err error) {
if err != nil { if err != nil {
return fmt.Errorf("Couldn't get meminfo: %s", err) return fmt.Errorf("Couldn't get meminfo: %s", err)
} }
glog.V(1).Infof("Set node_mem: %#v", memInfo) log.Debugf("Set node_mem: %#v", memInfo)
for k, v := range memInfo { for k, v := range memInfo {
if _, ok := c.metrics[k]; !ok { if _, ok := c.metrics[k]; !ok {
c.metrics[k] = prometheus.NewGauge(prometheus.GaugeOpts{ c.metrics[k] = prometheus.NewGauge(prometheus.GaugeOpts{

View File

@ -24,7 +24,6 @@ var (
) )
type netDevCollector struct { type netDevCollector struct {
metrics map[string]*prometheus.GaugeVec metrics map[string]*prometheus.GaugeVec
} }

View File

@ -19,7 +19,6 @@ const (
) )
type netStatCollector struct { type netStatCollector struct {
metrics map[string]prometheus.Gauge metrics map[string]prometheus.Gauge
} }

View File

@ -8,8 +8,8 @@ import (
"time" "time"
"github.com/beevik/ntp" "github.com/beevik/ntp"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
) )
var ( var (
@ -46,7 +46,7 @@ func (c *ntpCollector) Update(ch chan<- prometheus.Metric) (err error) {
return fmt.Errorf("Couldn't get ntp drift: %s", err) return fmt.Errorf("Couldn't get ntp drift: %s", err)
} }
drift := t.Sub(time.Now()) drift := t.Sub(time.Now())
glog.V(1).Infof("Set ntp_drift_seconds: %f", drift.Seconds()) log.Debugf("Set ntp_drift_seconds: %f", drift.Seconds())
c.drift.Set(drift.Seconds()) c.drift.Set(drift.Seconds())
c.drift.Collect(ch) c.drift.Collect(ch)
return err return err

View File

@ -3,14 +3,12 @@
package collector package collector
import ( import (
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
"github.com/soundcloud/go-runit/runit" "github.com/soundcloud/go-runit/runit"
) )
type runitCollector struct { type runitCollector struct {
state, stateDesired, stateNormal *prometheus.GaugeVec state, stateDesired, stateNormal *prometheus.GaugeVec
} }
@ -26,7 +24,6 @@ func NewRunitCollector() (Collector, error) {
) )
return &runitCollector{ return &runitCollector{
state: prometheus.NewGaugeVec( state: prometheus.NewGaugeVec(
prometheus.GaugeOpts{ prometheus.GaugeOpts{
Namespace: Namespace, Namespace: Namespace,
@ -69,11 +66,11 @@ func (c *runitCollector) Update(ch chan<- prometheus.Metric) error {
for _, service := range services { for _, service := range services {
status, err := service.Status() status, err := service.Status()
if err != nil { if err != nil {
glog.V(1).Infof("Couldn't get status for %s: %s, skipping...", service.Name, err) log.Debugf("Couldn't get status for %s: %s, skipping...", service.Name, err)
continue continue
} }
glog.V(1).Infof("%s is %d on pid %d for %d seconds", service.Name, status.State, status.Pid, status.Duration) log.Debugf("%s is %d on pid %d for %d seconds", service.Name, status.State, status.Pid, status.Duration)
c.state.WithLabelValues(service.Name).Set(float64(status.State)) c.state.WithLabelValues(service.Name).Set(float64(status.State))
c.stateDesired.WithLabelValues(service.Name).Set(float64(status.Want)) c.stateDesired.WithLabelValues(service.Name).Set(float64(status.Want))
if status.NormallyUp { if status.NormallyUp {

View File

@ -17,7 +17,6 @@ const (
) )
type statCollector struct { type statCollector struct {
cpu *prometheus.CounterVec cpu *prometheus.CounterVec
intr prometheus.Counter intr prometheus.Counter
ctxt prometheus.Counter ctxt prometheus.Counter
@ -35,7 +34,6 @@ func init() {
// network device stats. // network device stats.
func NewStatCollector() (Collector, error) { func NewStatCollector() (Collector, error) {
return &statCollector{ return &statCollector{
cpu: prometheus.NewCounterVec( cpu: prometheus.NewCounterVec(
prometheus.CounterOpts{ prometheus.CounterOpts{
Namespace: Namespace, Namespace: Namespace,

View File

@ -35,7 +35,6 @@ const (
) )
type tcpStatCollector struct { type tcpStatCollector struct {
metric *prometheus.GaugeVec metric *prometheus.GaugeVec
} }
@ -47,7 +46,6 @@ func init() {
// a new Collector exposing network stats. // a new Collector exposing network stats.
func NewTCPStatCollector() (Collector, error) { func NewTCPStatCollector() (Collector, error) {
return &tcpStatCollector{ return &tcpStatCollector{
metric: prometheus.NewGaugeVec( metric: prometheus.NewGaugeVec(
prometheus.GaugeOpts{ prometheus.GaugeOpts{
Namespace: Namespace, Namespace: Namespace,

View File

@ -13,8 +13,8 @@ import (
dto "github.com/prometheus/client_model/go" dto "github.com/prometheus/client_model/go"
"github.com/golang/glog"
"github.com/golang/protobuf/proto" "github.com/golang/protobuf/proto"
"github.com/prometheus/log"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/text" "github.com/prometheus/client_golang/text"
@ -37,7 +37,7 @@ 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.
glog.Infof("No directory specified, see --textfile.directory") log.Infof("No directory specified, see --textfile.directory")
} else { } else {
prometheus.SetMetricFamilyInjectionHook(parseTextFiles) prometheus.SetMetricFamilyInjectionHook(parseTextFiles)
} }
@ -65,13 +65,13 @@ func parseTextFiles() []*dto.MetricFamily {
path := filepath.Join(*textFileDirectory, f.Name()) path := filepath.Join(*textFileDirectory, f.Name())
file, err := os.Open(path) file, err := os.Open(path)
if err != nil { if err != nil {
glog.Errorf("Error opening %s: %v", path, err) log.Errorf("Error opening %s: %v", path, err)
error = 1.0 error = 1.0
continue continue
} }
parsedFamilies, err := parser.TextToMetricFamilies(file) parsedFamilies, err := parser.TextToMetricFamilies(file)
if err != nil { if err != nil {
glog.Errorf("Error parsing %s: %v", path, err) log.Errorf("Error parsing %s: %v", path, err)
error = 1.0 error = 1.0
continue continue
} }

View File

@ -5,12 +5,11 @@ package collector
import ( import (
"time" "time"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
) )
type timeCollector struct { type timeCollector struct {
metric prometheus.Counter metric prometheus.Counter
} }
@ -22,7 +21,6 @@ func init() {
// the current system time in seconds since epoch. // the current system time in seconds since epoch.
func NewTimeCollector() (Collector, error) { func NewTimeCollector() (Collector, error) {
return &timeCollector{ return &timeCollector{
metric: prometheus.NewCounter(prometheus.CounterOpts{ metric: prometheus.NewCounter(prometheus.CounterOpts{
Namespace: Namespace, Namespace: Namespace,
Name: "time", Name: "time",
@ -33,7 +31,7 @@ func NewTimeCollector() (Collector, error) {
func (c *timeCollector) Update(ch chan<- prometheus.Metric) (err error) { func (c *timeCollector) Update(ch chan<- prometheus.Metric) (err error) {
now := time.Now() now := time.Now()
glog.V(1).Infof("Set time: %f", now.Unix()) log.Debugf("Set time: %f", now.Unix())
c.metric.Set(float64(now.Unix())) c.metric.Set(float64(now.Unix()))
c.metric.Collect(ch) c.metric.Collect(ch)
return err return err

View File

@ -13,8 +13,9 @@ import (
"syscall" "syscall"
"time" "time"
"github.com/golang/glog"
"github.com/prometheus/client_golang/prometheus" "github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/log"
"github.com/prometheus/node_exporter/collector" "github.com/prometheus/node_exporter/collector"
) )
@ -93,10 +94,10 @@ func Execute(name string, c collector.Collector, ch chan<- prometheus.Metric) {
var result string var result string
if err != nil { if err != nil {
glog.Infof("ERROR: %s failed after %fs: %s", name, duration.Seconds(), err) log.Infof("ERROR: %s failed after %fs: %s", name, duration.Seconds(), err)
result = "error" result = "error"
} else { } else {
glog.Infof("OK: %s success after %fs.", name, duration.Seconds()) log.Infof("OK: %s success after %fs.", name, duration.Seconds())
result = "success" result = "success"
} }
scrapeDurations.WithLabelValues(name, result).Observe(duration.Seconds()) scrapeDurations.WithLabelValues(name, result).Observe(duration.Seconds())
@ -135,12 +136,12 @@ func main() {
} }
collectors, err := loadCollectors() collectors, err := loadCollectors()
if err != nil { if err != nil {
glog.Fatalf("Couldn't load collectors: %s", err) log.Fatalf("Couldn't load collectors: %s", err)
} }
glog.Infof("Enabled collectors:") log.Infof("Enabled collectors:")
for n, _ := range collectors { for n, _ := range collectors {
glog.Infof(" - %s", n) log.Infof(" - %s", n)
} }
nodeCollector := NodeCollector{collectors: collectors} nodeCollector := NodeCollector{collectors: collectors}
@ -152,7 +153,7 @@ func main() {
handler := prometheus.Handler() handler := prometheus.Handler()
if *authUser != "" || *authPass != "" { if *authUser != "" || *authPass != "" {
if *authUser == "" || *authPass == "" { if *authUser == "" || *authPass == "" {
glog.Fatal("You need to specify -auth.user and -auth.pass to enable basic auth") log.Fatal("You need to specify -auth.user and -auth.pass to enable basic auth")
} }
handler = &basicAuthHandler{ handler = &basicAuthHandler{
handler: prometheus.Handler().ServeHTTP, handler: prometheus.Handler().ServeHTTP,
@ -172,9 +173,9 @@ func main() {
</html>`)) </html>`))
}) })
glog.Infof("Starting node_exporter v%s at %s", Version, *listenAddress) log.Infof("Starting node_exporter v%s at %s", Version, *listenAddress)
err = http.ListenAndServe(*listenAddress, nil) err = http.ListenAndServe(*listenAddress, nil)
if err != nil { if err != nil {
glog.Fatal(err) log.Fatal(err)
} }
} }