Added response_timeout property

This commit is contained in:
Pierre Tessier 2016-11-07 11:34:02 -05:00
parent 5d3850c44e
commit eb4c000d4f
2 changed files with 18 additions and 2 deletions

View File

@ -13,6 +13,17 @@ Example for Kubernetes apiserver
urls = ["http://my-kube-apiserver:8080/metrics"] urls = ["http://my-kube-apiserver:8080/metrics"]
``` ```
Specify a 10 second timeout for slower/over-loaded clients
```toml
# Get all metrics from Kube-apiserver
[[inputs.prometheus]]
# An array of urls to scrape metrics from.
urls = ["http://my-kube-apiserver:8080/metrics"]
# Specify timeout in seconds for slower prometheus clients (default is 3)
response_timeout = 10
```
You can use more complex configuration You can use more complex configuration
to filter and some tags to filter and some tags

View File

@ -21,6 +21,8 @@ type Prometheus struct {
// Bearer Token authorization file path // Bearer Token authorization file path
BearerToken string `toml:"bearer_token"` BearerToken string `toml:"bearer_token"`
ResponseTimeout int `toml:"response_timeout"`
// Path to CA file // Path to CA file
SSLCA string `toml:"ssl_ca"` SSLCA string `toml:"ssl_ca"`
// Path to host cert file // Path to host cert file
@ -38,6 +40,9 @@ var sampleConfig = `
## Use bearer token for authorization ## Use bearer token for authorization
# bearer_token = /path/to/bearer/token # bearer_token = /path/to/bearer/token
## Specify timeout in seconds for slower prometheus clients (default is 3)
# response_timeout = 3
## Optional SSL Config ## Optional SSL Config
# ssl_ca = /path/to/cafile # ssl_ca = /path/to/cafile
# ssl_cert = /path/to/certfile # ssl_cert = /path/to/certfile
@ -105,7 +110,7 @@ func (p *Prometheus) gatherURL(url string, acc telegraf.Accumulator) error {
}).Dial, }).Dial,
TLSHandshakeTimeout: 5 * time.Second, TLSHandshakeTimeout: 5 * time.Second,
TLSClientConfig: tlsCfg, TLSClientConfig: tlsCfg,
ResponseHeaderTimeout: time.Duration(3 * time.Second), ResponseHeaderTimeout: time.Duration(time.Duration(p.ResponseTimeout) * time.Second),
DisableKeepAlives: true, DisableKeepAlives: true,
} }
@ -148,6 +153,6 @@ func (p *Prometheus) gatherURL(url string, acc telegraf.Accumulator) error {
func init() { func init() {
inputs.Add("prometheus", func() telegraf.Input { inputs.Add("prometheus", func() telegraf.Input {
return &Prometheus{} return &Prometheus{ResponseTimeout: 3}
}) })
} }