Code formatted, Readme updated based on example

closes #695
This commit is contained in:
Andrei Burd 2016-02-14 21:12:21 +02:00 committed by Michele Fadda
parent ec8f51beaf
commit 0d12f2db85
5 changed files with 47 additions and 14 deletions

View File

@ -19,6 +19,7 @@ they would like to output. Currently supports: "influx" and "graphite"
- [#683](https://github.com/influxdata/telegraf/pull/683): PostGRES input plugin: add pg_stat_bgwriter. Thanks @menardorama! - [#683](https://github.com/influxdata/telegraf/pull/683): PostGRES input plugin: add pg_stat_bgwriter. Thanks @menardorama!
- [#679](https://github.com/influxdata/telegraf/pull/679): File/stdout output plugin. - [#679](https://github.com/influxdata/telegraf/pull/679): File/stdout output plugin.
- [#679](https://github.com/influxdata/telegraf/pull/679): Support for arbitrary output data formats. - [#679](https://github.com/influxdata/telegraf/pull/679): Support for arbitrary output data formats.
- [#695](https://github.com/influxdata/telegraf/pull/695): raindrops input plugin. Thanks @burdandrei!
### Bugfixes ### Bugfixes
- [#443](https://github.com/influxdata/telegraf/issues/443): Fix Ping command timeout parameter on Linux. - [#443](https://github.com/influxdata/telegraf/issues/443): Fix Ping command timeout parameter on Linux.

View File

@ -326,7 +326,7 @@ which would take some time to replicate.
To overcome this situation we've decided to use docker containers to provide a To overcome this situation we've decided to use docker containers to provide a
fast and reproducible environment to test those services which require it. fast and reproducible environment to test those services which require it.
For other situations For other situations
(i.e: https://github.com/influxdata/telegraf/blob/master/plugins/redis/redis_test.go) (i.e: https://github.com/influxdata/telegraf/blob/master/plugins/inputs/redis/redis_test.go)
a simple mock will suffice. a simple mock will suffice.
To execute Telegraf tests follow these simple steps: To execute Telegraf tests follow these simple steps:

View File

@ -1,15 +1,49 @@
# Raindrops Input Plugin # Raindrops Input Plugin
The [raindrops](http://raindrops.bogomips.org/) plugin reads from The [raindrops](http://raindrops.bogomips.org/) plugin reads from
specified raindops middleware URI and adds stats to InfluxDB. specified raindops [middleware](http://raindrops.bogomips.org/Raindrops/Middleware.html) URI and adds stats to InfluxDB.
### Configuration: ### Configuration:
```toml ```toml
# Read raindrops stats # Read raindrops stats
[[inputs.raindrops]] [[inputs.raindrops]]
urls = ["http://localhost/_raindrops"] urls = ["http://localhost:8080/_raindrops"]
``` ```
### Measurements & Fields:
- raindrops
- calling (integer, count)
- writing (integer, count)
- raindrops_listen
- active (integer, bytes)
- queued (integer, bytes)
### Tags: ### Tags:
- Multiple listeners are tagged with IP:Port/Socket, ie `0.0.0.0:8080` or `/tmp/unicorn` - Raindops calling/writing of all the workers:
- server
- port
- raindrops_listen (ip:port):
- ip
- port
- raindrops_listen (Unix Socket):
- socket
### Example Output:
```
$ ./telegraf -config telegraf.conf -input-filter raindrops -test
* Plugin: raindrops, Collection 1
> raindrops,port=8080,server=localhost calling=0i,writing=0i 1455479896806238204
> raindrops_listen,ip=0.0.0.0,port=8080 active=0i,queued=0i 1455479896806561938
> raindrops_listen,ip=0.0.0.0,port=8081 active=1i,queued=0i 1455479896806605749
> raindrops_listen,ip=127.0.0.1,port=8082 active=0i,queued=0i 1455479896806646315
> raindrops_listen,ip=0.0.0.0,port=8083 active=0i,queued=0i 1455479896806683252
> raindrops_listen,ip=0.0.0.0,port=8084 active=0i,queued=0i 1455479896806712025
> raindrops_listen,ip=0.0.0.0,port=3000 active=0i,queued=0i 1455479896806779197
> raindrops_listen,socket=/tmp/listen.me active=0i,queued=0i 1455479896806813907
```

View File

@ -22,7 +22,7 @@ type Raindrops struct {
var sampleConfig = ` var sampleConfig = `
### An array of raindrops middleware URI to gather stats. ### An array of raindrops middleware URI to gather stats.
urls = ["http://localhost/_raindrops"] urls = ["http://localhost:8080/_raindrops"]
` `
func (r *Raindrops) SampleConfig() string { func (r *Raindrops) SampleConfig() string {
@ -119,7 +119,7 @@ func (r *Raindrops) gatherUrl(addr *url.URL, acc telegraf.Accumulator) error {
iterate = false iterate = false
break break
} }
if strings.Compare(active_line_str, "\n") == 0{ if strings.Compare(active_line_str, "\n") == 0 {
break break
} }
queued_line_str, queued_err = buf.ReadString('\n') queued_line_str, queued_err = buf.ReadString('\n')
@ -153,8 +153,7 @@ func (r *Raindrops) gatherUrl(addr *url.URL, acc telegraf.Accumulator) error {
"socket": listen_name, "socket": listen_name,
} }
} }
fmt.Println("raindropssock", lis, tags) acc.AddFields("raindrops_listen", lis, tags)
acc.AddFields("raindropssock", lis, tags)
} }
return nil return nil
} }

View File

@ -99,10 +99,9 @@ func TestRaindropsGeneratesMetrics(t *testing.T) {
"port": "8081", "port": "8081",
"ip": "0.0.0.0", "ip": "0.0.0.0",
} }
fields = map[string]interface {} { fields = map[string]interface{}{
"active": uint64(3), "active": uint64(3),
"queued": uint64(4), "queued": uint64(4),
} }
fmt.Println("raindropssock_test", fields, tags) acc.AssertContainsTaggedFields(t, "raindrops_listen", fields, tags)
acc.AssertContainsTaggedFields(t, "raindropssock", fields, tags)
} }