Handle empty properties when collecting interface metrics (#20)

Instead of logging an error, check if a property is empty before attempting to
call strconv.ParseFloat on it.

ERRO[0005] error parsing interface metric value device=gw error="strconv.ParseFloat: parsing \"\": invalid syntax" interface=ether2 property=tx-drop value=
This commit is contained in:
Jarred Trainor 2018-10-31 19:40:11 -07:00 committed by Steve Brunton
parent 25911b4e60
commit 0f7d5bea2c

View File

@ -73,17 +73,18 @@ func (c *interfaceCollector) collectForStat(re *proto.Sentence, ctx *collectorCo
func (c *interfaceCollector) collectMetricForProperty(property, iface, comment string, re *proto.Sentence, ctx *collectorContext) { func (c *interfaceCollector) collectMetricForProperty(property, iface, comment string, re *proto.Sentence, ctx *collectorContext) {
desc := c.descriptions[property] desc := c.descriptions[property]
v, err := strconv.ParseFloat(re.Map[property], 64) if value := re.Map[property]; value != "" {
v, err := strconv.ParseFloat(value, 64)
if err != nil { if err != nil {
log.WithFields(log.Fields{ log.WithFields(log.Fields{
"device": ctx.device.Name, "device": ctx.device.Name,
"interface": iface, "interface": iface,
"property": property, "property": property,
"value": re.Map[property], "value": value,
"error": err, "error": err,
}).Error("error parsing interface metric value") }).Error("error parsing interface metric value")
return return
} }
ctx.ch <- prometheus.MustNewConstMetric(desc, prometheus.CounterValue, v, ctx.device.Name, ctx.device.Address, iface, comment) ctx.ch <- prometheus.MustNewConstMetric(desc, prometheus.CounterValue, v, ctx.device.Name, ctx.device.Address, iface, comment)
} }
}