Fix apache input creation of transport on every gather.
This commit is contained in:
		
							parent
							
								
									c28ffb11cb
								
							
						
					
					
						commit
						e7ad2d0463
					
				|  | @ -29,6 +29,8 @@ type Apache struct { | ||||||
| 	SSLKey string `toml:"ssl_key"` | 	SSLKey string `toml:"ssl_key"` | ||||||
| 	// Use SSL but skip chain & host verification
 | 	// Use SSL but skip chain & host verification
 | ||||||
| 	InsecureSkipVerify bool | 	InsecureSkipVerify bool | ||||||
|  | 
 | ||||||
|  | 	client *http.Client | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| var sampleConfig = ` | var sampleConfig = ` | ||||||
|  | @ -66,6 +68,14 @@ func (n *Apache) Gather(acc telegraf.Accumulator) error { | ||||||
| 		n.ResponseTimeout.Duration = time.Second * 5 | 		n.ResponseTimeout.Duration = time.Second * 5 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if n.client == nil { | ||||||
|  | 		client, err := n.createHttpClient() | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  | 		n.client = client | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	var wg sync.WaitGroup | 	var wg sync.WaitGroup | ||||||
| 	wg.Add(len(n.Urls)) | 	wg.Add(len(n.Urls)) | ||||||
| 	for _, u := range n.Urls { | 	for _, u := range n.Urls { | ||||||
|  | @ -85,31 +95,24 @@ func (n *Apache) Gather(acc telegraf.Accumulator) error { | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (n *Apache) gatherUrl(addr *url.URL, acc telegraf.Accumulator) error { | func (n *Apache) createHttpClient() (*http.Client, error) { | ||||||
| 
 |  | ||||||
| 	var tr *http.Transport |  | ||||||
| 
 |  | ||||||
| 	if addr.Scheme == "https" { |  | ||||||
| 	tlsCfg, err := internal.GetTLSConfig( | 	tlsCfg, err := internal.GetTLSConfig( | ||||||
| 		n.SSLCert, n.SSLKey, n.SSLCA, n.InsecureSkipVerify) | 		n.SSLCert, n.SSLKey, n.SSLCA, n.InsecureSkipVerify) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 			return err | 		return nil, err | ||||||
| 		} |  | ||||||
| 		tr = &http.Transport{ |  | ||||||
| 			ResponseHeaderTimeout: time.Duration(3 * time.Second), |  | ||||||
| 			TLSClientConfig:       tlsCfg, |  | ||||||
| 		} |  | ||||||
| 	} else { |  | ||||||
| 		tr = &http.Transport{ |  | ||||||
| 			ResponseHeaderTimeout: time.Duration(3 * time.Second), |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	client := &http.Client{ | 	client := &http.Client{ | ||||||
| 		Transport: tr, | 		Transport: &http.Transport{ | ||||||
|  | 			TLSClientConfig: tlsCfg, | ||||||
|  | 		}, | ||||||
| 		Timeout: n.ResponseTimeout.Duration, | 		Timeout: n.ResponseTimeout.Duration, | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	return client, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (n *Apache) gatherUrl(addr *url.URL, acc telegraf.Accumulator) error { | ||||||
| 	req, err := http.NewRequest("GET", addr.String(), nil) | 	req, err := http.NewRequest("GET", addr.String(), nil) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return fmt.Errorf("error on new request to %s : %s\n", addr.String(), err) | 		return fmt.Errorf("error on new request to %s : %s\n", addr.String(), err) | ||||||
|  | @ -119,7 +122,7 @@ func (n *Apache) gatherUrl(addr *url.URL, acc telegraf.Accumulator) error { | ||||||
| 		req.SetBasicAuth(n.Username, n.Password) | 		req.SetBasicAuth(n.Username, n.Password) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	resp, err := client.Do(req) | 	resp, err := n.client.Do(req) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return fmt.Errorf("error on request to %s : %s\n", addr.String(), err) | 		return fmt.Errorf("error on request to %s : %s\n", addr.String(), err) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue