Allow numeric and non-string values for tag_keys. (#1782)
* Allow numeric and non-string values for tag_keys. According to the go documentation the JSON deserializer only produces these base types in output: - string - bool - float64 - nil With this patch bool, float64 and nil values get converted to a string when their field key is specified in tag_keys. Previously the field was simply discarded. * Updated handling of nil for passing tests. The automated tests are less than trivial to reproduece locally for me, so I hope CircleCI wonn't mind... * Updated changelog entries with PR and issue links.
This commit is contained in:
		
							parent
							
								
									100501ba72
								
							
						
					
					
						commit
						9ea3dbeee8
					
				|  | @ -4,6 +4,7 @@ | |||
| 
 | ||||
| ### Features | ||||
| 
 | ||||
| - [#1782](https://github.com/influxdata/telegraf/pull/1782): Allow numeric and non-string values for tag_keys. | ||||
| - [#1694](https://github.com/influxdata/telegraf/pull/1694): Adding Gauge and Counter metric types. | ||||
| - [#1606](https://github.com/influxdata/telegraf/pull/1606): Remove carraige returns from exec plugin output on Windows | ||||
| - [#1674](https://github.com/influxdata/telegraf/issues/1674): elasticsearch input: configurable timeout. | ||||
|  | @ -23,6 +24,7 @@ | |||
| 
 | ||||
| ### Bugfixes | ||||
| 
 | ||||
| - [#1746](https://github.com/influxdata/telegraf/issues/1746): Fix handling of non-string values for JSON keys listed in tag_keys. | ||||
| - [#1628](https://github.com/influxdata/telegraf/issues/1628): Fix mongodb input panic on version 2.2. | ||||
| - [#1733](https://github.com/influxdata/telegraf/issues/1733): Fix statsd scientific notation parsing | ||||
| - [#1716](https://github.com/influxdata/telegraf/issues/1716): Sensors plugin strconv.ParseFloat: parsing "": invalid syntax | ||||
|  |  | |||
|  | @ -35,6 +35,10 @@ func (p *JSONParser) Parse(buf []byte) ([]telegraf.Metric, error) { | |||
| 		switch v := jsonOut[tag].(type) { | ||||
| 		case string: | ||||
| 			tags[tag] = v | ||||
| 		case bool: | ||||
| 			tags[tag] = strconv.FormatBool(v) | ||||
| 		case float64: | ||||
| 			tags[tag] = strconv.FormatFloat(v, 'f', -1, 64) | ||||
| 		} | ||||
| 		delete(jsonOut, tag) | ||||
| 	} | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue