parent
							
								
									7fc57812a7
								
							
						
					
					
						commit
						a9f03a72f5
					
				|  | @ -42,6 +42,7 @@ plugins, not just statsd. | |||
| - [#1898](https://github.com/influxdata/telegraf/issues/1898): Support negative statsd counters. | ||||
| - [#1921](https://github.com/influxdata/telegraf/issues/1921): Elasticsearch cluster stats support. | ||||
| - [#1942](https://github.com/influxdata/telegraf/pull/1942): Change Amazon Kinesis output plugin to use the built-in serializer plugins. | ||||
| - [#1980](https://github.com/influxdata/telegraf/issues/1980): Hide username/password from elasticsearch error log messages. | ||||
| 
 | ||||
| ### Bugfixes | ||||
| 
 | ||||
|  |  | |||
|  | @ -4,6 +4,7 @@ import ( | |||
| 	"encoding/json" | ||||
| 	"fmt" | ||||
| 	"net/http" | ||||
| 	"regexp" | ||||
| 	"sync" | ||||
| 	"time" | ||||
| 
 | ||||
|  | @ -16,6 +17,9 @@ import ( | |||
| 	"strings" | ||||
| ) | ||||
| 
 | ||||
| // mask for masking username/password from error messages
 | ||||
| var mask = regexp.MustCompile(`https?:\/\/\S+:\S+@`) | ||||
| 
 | ||||
| // Nodestats are always generated, so simply define a constant for these endpoints
 | ||||
| const statsPath = "/_nodes/stats" | ||||
| const statsPathLocal = "/_nodes/_local/stats" | ||||
|  | @ -149,7 +153,7 @@ func (e *Elasticsearch) Gather(acc telegraf.Accumulator) error { | |||
| 		e.client = client | ||||
| 	} | ||||
| 
 | ||||
| 	errChan := errchan.New(len(e.Servers)) | ||||
| 	errChan := errchan.New(len(e.Servers) * 3) | ||||
| 	var wg sync.WaitGroup | ||||
| 	wg.Add(len(e.Servers)) | ||||
| 
 | ||||
|  | @ -172,17 +176,26 @@ func (e *Elasticsearch) Gather(acc telegraf.Accumulator) error { | |||
| 
 | ||||
| 			// Always gather node states
 | ||||
| 			if err := e.gatherNodeStats(url, acc); err != nil { | ||||
| 				err = fmt.Errorf(mask.ReplaceAllString(err.Error(), "http(s)://XXX:XXX@")) | ||||
| 				errChan.C <- err | ||||
| 				return | ||||
| 			} | ||||
| 
 | ||||
| 			if e.ClusterHealth { | ||||
| 				url = s + "/_cluster/health?level=indices" | ||||
| 				e.gatherClusterHealth(url, acc) | ||||
| 				if err := e.gatherClusterHealth(url, acc); err != nil { | ||||
| 					err = fmt.Errorf(mask.ReplaceAllString(err.Error(), "http(s)://XXX:XXX@")) | ||||
| 					errChan.C <- err | ||||
| 					return | ||||
| 				} | ||||
| 			} | ||||
| 
 | ||||
| 			if e.ClusterStats && e.isMaster { | ||||
| 				e.gatherClusterStats(s+"/_cluster/stats", acc) | ||||
| 				if err := e.gatherClusterStats(s+"/_cluster/stats", acc); err != nil { | ||||
| 					err = fmt.Errorf(mask.ReplaceAllString(err.Error(), "http(s)://XXX:XXX@")) | ||||
| 					errChan.C <- err | ||||
| 					return | ||||
| 				} | ||||
| 			} | ||||
| 		}(serv, acc) | ||||
| 	} | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue