Add compatibility for Kibana 6.4 and later (#6923)
This commit is contained in:
parent
fb1b29cc20
commit
bc3429ed48
|
@ -42,6 +42,7 @@ with following rules:
|
||||||
|
|
||||||
- kibana
|
- kibana
|
||||||
- status_code: integer (1, 2, 3, 0)
|
- status_code: integer (1, 2, 3, 0)
|
||||||
|
- heap_total_bytes: integer
|
||||||
- heap_max_bytes: integer
|
- heap_max_bytes: integer
|
||||||
- heap_used_bytes: integer
|
- heap_used_bytes: integer
|
||||||
- uptime_ms: integer
|
- uptime_ms: integer
|
||||||
|
@ -52,12 +53,12 @@ with following rules:
|
||||||
|
|
||||||
### Tags
|
### Tags
|
||||||
|
|
||||||
- status (Kibana health: green, yellow, red)
|
|
||||||
- name (Kibana reported name)
|
- name (Kibana reported name)
|
||||||
- uuid (Kibana reported UUID)
|
|
||||||
- version (Kibana version)
|
|
||||||
- source (Kibana server hostname or IP)
|
- source (Kibana server hostname or IP)
|
||||||
|
- status (Kibana health: green, yellow, red)
|
||||||
|
- version (Kibana version)
|
||||||
|
|
||||||
### Example Output
|
### Example Output
|
||||||
|
```
|
||||||
kibana,host=myhost,name=my-kibana,source=localhost:5601,version=6.3.2 concurrent_connections=0i,heap_max_bytes=136478720i,heap_used_bytes=119231088i,response_time_avg_ms=0i,response_time_max_ms=0i,status="green",status_code=1i,uptime_ms=2187428019i 1534864502000000000
|
kibana,host=myhost,name=my-kibana,source=localhost:5601,status=green,version=6.5.4 concurrent_connections=8i,heap_max_bytes=447778816i,heap_total_bytes=447778816i,heap_used_bytes=380603352i,requests_per_sec=1,response_time_avg_ms=57.6,response_time_max_ms=220i,status_code=1i,uptime_ms=6717489805i 1534864502000000000
|
||||||
|
```
|
||||||
|
|
|
@ -4,6 +4,7 @@ import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
@ -54,7 +55,9 @@ type responseTimes struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type process struct {
|
type process struct {
|
||||||
Mem mem `json:"mem"`
|
Mem mem `json:"mem"`
|
||||||
|
Memory memory `json:"memory"`
|
||||||
|
UptimeInMillis int64 `json:"uptime_in_millis"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type requests struct {
|
type requests struct {
|
||||||
|
@ -66,6 +69,15 @@ type mem struct {
|
||||||
HeapUsedInBytes int64 `json:"heap_used_in_bytes"`
|
HeapUsedInBytes int64 `json:"heap_used_in_bytes"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type memory struct {
|
||||||
|
Heap heap `json:"heap"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type heap struct {
|
||||||
|
TotalInBytes int64 `json:"total_in_bytes"`
|
||||||
|
UsedInBytes int64 `json:"used_in_bytes"`
|
||||||
|
}
|
||||||
|
|
||||||
const sampleConfig = `
|
const sampleConfig = `
|
||||||
## specify a list of one or more Kibana servers
|
## specify a list of one or more Kibana servers
|
||||||
servers = ["http://localhost:5601"]
|
servers = ["http://localhost:5601"]
|
||||||
|
@ -187,15 +199,37 @@ func (k *Kibana) gatherKibanaStatus(baseUrl string, acc telegraf.Accumulator) er
|
||||||
tags["status"] = kibanaStatus.Status.Overall.State
|
tags["status"] = kibanaStatus.Status.Overall.State
|
||||||
|
|
||||||
fields["status_code"] = mapHealthStatusToCode(kibanaStatus.Status.Overall.State)
|
fields["status_code"] = mapHealthStatusToCode(kibanaStatus.Status.Overall.State)
|
||||||
|
|
||||||
fields["uptime_ms"] = kibanaStatus.Metrics.UptimeInMillis
|
|
||||||
fields["concurrent_connections"] = kibanaStatus.Metrics.ConcurrentConnections
|
fields["concurrent_connections"] = kibanaStatus.Metrics.ConcurrentConnections
|
||||||
fields["heap_max_bytes"] = kibanaStatus.Metrics.Process.Mem.HeapMaxInBytes
|
|
||||||
fields["heap_used_bytes"] = kibanaStatus.Metrics.Process.Mem.HeapUsedInBytes
|
|
||||||
fields["response_time_avg_ms"] = kibanaStatus.Metrics.ResponseTimes.AvgInMillis
|
fields["response_time_avg_ms"] = kibanaStatus.Metrics.ResponseTimes.AvgInMillis
|
||||||
fields["response_time_max_ms"] = kibanaStatus.Metrics.ResponseTimes.MaxInMillis
|
fields["response_time_max_ms"] = kibanaStatus.Metrics.ResponseTimes.MaxInMillis
|
||||||
fields["requests_per_sec"] = float64(kibanaStatus.Metrics.Requests.Total) / float64(kibanaStatus.Metrics.CollectionIntervalInMilles) * 1000
|
fields["requests_per_sec"] = float64(kibanaStatus.Metrics.Requests.Total) / float64(kibanaStatus.Metrics.CollectionIntervalInMilles) * 1000
|
||||||
|
|
||||||
|
versionArray := strings.Split(kibanaStatus.Version.Number, ".")
|
||||||
|
arrayElement := 1
|
||||||
|
|
||||||
|
if len(versionArray) > 1 {
|
||||||
|
arrayElement = 2
|
||||||
|
}
|
||||||
|
versionNumber, err := strconv.ParseFloat(strings.Join(versionArray[:arrayElement], "."), 64)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Same value will be assigned to both the metrics [heap_max_bytes and heap_total_bytes ]
|
||||||
|
// Which keeps the code backward compatible
|
||||||
|
if versionNumber >= 6.4 {
|
||||||
|
fields["uptime_ms"] = kibanaStatus.Metrics.Process.UptimeInMillis
|
||||||
|
fields["heap_max_bytes"] = kibanaStatus.Metrics.Process.Memory.Heap.TotalInBytes
|
||||||
|
fields["heap_total_bytes"] = kibanaStatus.Metrics.Process.Memory.Heap.TotalInBytes
|
||||||
|
fields["heap_used_bytes"] = kibanaStatus.Metrics.Process.Memory.Heap.UsedInBytes
|
||||||
|
} else {
|
||||||
|
fields["uptime_ms"] = kibanaStatus.Metrics.UptimeInMillis
|
||||||
|
fields["heap_max_bytes"] = kibanaStatus.Metrics.Process.Mem.HeapMaxInBytes
|
||||||
|
fields["heap_total_bytes"] = kibanaStatus.Metrics.Process.Mem.HeapMaxInBytes
|
||||||
|
fields["heap_used_bytes"] = kibanaStatus.Metrics.Process.Mem.HeapUsedInBytes
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
acc.AddFields("kibana", fields, tags)
|
acc.AddFields("kibana", fields, tags)
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -9,7 +9,7 @@ import (
|
||||||
"github.com/influxdata/telegraf/testutil"
|
"github.com/influxdata/telegraf/testutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
func defaultTags() map[string]string {
|
func defaultTags6_3() map[string]string {
|
||||||
return map[string]string{
|
return map[string]string{
|
||||||
"name": "my-kibana",
|
"name": "my-kibana",
|
||||||
"source": "example.com:5601",
|
"source": "example.com:5601",
|
||||||
|
@ -18,6 +18,15 @@ func defaultTags() map[string]string {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func defaultTags6_5() map[string]string {
|
||||||
|
return map[string]string{
|
||||||
|
"name": "my-kibana",
|
||||||
|
"source": "example.com:5601",
|
||||||
|
"version": "6.5.4",
|
||||||
|
"status": "green",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
type transportMock struct {
|
type transportMock struct {
|
||||||
statusCode int
|
statusCode int
|
||||||
body string
|
body string
|
||||||
|
@ -41,22 +50,35 @@ func (t *transportMock) RoundTrip(r *http.Request) (*http.Response, error) {
|
||||||
return res, nil
|
return res, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkKibanaStatusResult(t *testing.T, acc *testutil.Accumulator) {
|
func checkKibanaStatusResult(version string, t *testing.T, acc *testutil.Accumulator) {
|
||||||
tags := defaultTags()
|
if version == "6.3.2" {
|
||||||
acc.AssertContainsTaggedFields(t, "kibana", kibanaStatusExpected, tags)
|
tags := defaultTags6_3()
|
||||||
|
acc.AssertContainsTaggedFields(t, "kibana", kibanaStatusExpected6_3, tags)
|
||||||
|
} else {
|
||||||
|
tags := defaultTags6_5()
|
||||||
|
acc.AssertContainsTaggedFields(t, "kibana", kibanaStatusExpected6_5, tags)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGather(t *testing.T) {
|
func TestGather(t *testing.T) {
|
||||||
ks := newKibanahWithClient()
|
ks := newKibanahWithClient()
|
||||||
ks.Servers = []string{"http://example.com:5601"}
|
ks.Servers = []string{"http://example.com:5601"}
|
||||||
ks.client.Transport = newTransportMock(http.StatusOK, kibanaStatusResponse)
|
// Unit test for Kibana version < 6.5
|
||||||
|
ks.client.Transport = newTransportMock(http.StatusOK, kibanaStatusResponse6_3)
|
||||||
var acc testutil.Accumulator
|
var acc1 testutil.Accumulator
|
||||||
if err := acc.GatherError(ks.Gather); err != nil {
|
if err := acc1.GatherError(ks.Gather); err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
checkKibanaStatusResult(defaultTags6_3()["version"], t, &acc1)
|
||||||
|
|
||||||
|
//Unit test for Kibana version >= 6.5
|
||||||
|
ks.client.Transport = newTransportMock(http.StatusOK, kibanaStatusResponse6_5)
|
||||||
|
var acc2 testutil.Accumulator
|
||||||
|
if err := acc2.GatherError(ks.Gather); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
checkKibanaStatusResult(defaultTags6_5()["version"], t, &acc2)
|
||||||
|
|
||||||
checkKibanaStatusResult(t, &acc)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func newKibanahWithClient() *Kibana {
|
func newKibanahWithClient() *Kibana {
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
package kibana
|
package kibana
|
||||||
|
|
||||||
const kibanaStatusResponse = `
|
const kibanaStatusResponse6_3 = `
|
||||||
{
|
{
|
||||||
"name": "my-kibana",
|
"name": "my-kibana",
|
||||||
"uuid": "00000000-0000-0000-0000-000000000000",
|
"uuid": "00000000-0000-0000-0000-000000000000",
|
||||||
|
@ -187,8 +187,9 @@ const kibanaStatusResponse = `
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
|
|
||||||
var kibanaStatusExpected = map[string]interface{}{
|
var kibanaStatusExpected6_3 = map[string]interface{}{
|
||||||
"status_code": 1,
|
"status_code": 1,
|
||||||
|
"heap_total_bytes": int64(149954560),
|
||||||
"heap_max_bytes": int64(149954560),
|
"heap_max_bytes": int64(149954560),
|
||||||
"heap_used_bytes": int64(126274392),
|
"heap_used_bytes": int64(126274392),
|
||||||
"uptime_ms": int64(2173595336),
|
"uptime_ms": int64(2173595336),
|
|
@ -0,0 +1,227 @@
|
||||||
|
package kibana
|
||||||
|
|
||||||
|
const kibanaStatusResponse6_5 = `
|
||||||
|
{
|
||||||
|
"name": "my-kibana",
|
||||||
|
"uuid": "00000000-0000-0000-0000-000000000000",
|
||||||
|
"version": {
|
||||||
|
"number": "6.5.4",
|
||||||
|
"build_hash": "53d0c6758ac3fb38a3a1df198c1d4c87765e63f7",
|
||||||
|
"build_number": 17307,
|
||||||
|
"build_snapshot": false
|
||||||
|
},
|
||||||
|
"status": {
|
||||||
|
"overall": {
|
||||||
|
"state": "green",
|
||||||
|
"title": "Green",
|
||||||
|
"nickname": "Looking good",
|
||||||
|
"icon": "success",
|
||||||
|
"since": "2018-07-27T07:37:42.567Z"
|
||||||
|
},
|
||||||
|
"statuses": [{
|
||||||
|
"id": "plugin:kibana@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.567Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:elasticsearch@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:04.920Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:xpack_main@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.393Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:searchprofiler@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.395Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:tilemap@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.396Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:watcher@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.397Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:license_management@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.668Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:index_management@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.399Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:timelion@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.912Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:logtrail@0.1.29",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.919Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:monitoring@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.922Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:grokdebugger@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.400Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:dashboard_mode@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.928Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:logstash@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.401Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:apm@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.950Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:console@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.958Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:console_extensions@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.961Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:metrics@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-27T07:37:42.965Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "plugin:reporting@6.5.4",
|
||||||
|
"state": "green",
|
||||||
|
"icon": "success",
|
||||||
|
"message": "Ready",
|
||||||
|
"since": "2018-07-28T10:07:02.402Z"
|
||||||
|
}]
|
||||||
|
},
|
||||||
|
"metrics": {
|
||||||
|
"last_updated": "2020-01-15T09:40:17.733Z",
|
||||||
|
"collection_interval_in_millis": 5000,
|
||||||
|
"process": {
|
||||||
|
"memory": {
|
||||||
|
"heap": {
|
||||||
|
"total_in_bytes": 149954560,
|
||||||
|
"used_in_bytes": 126274392,
|
||||||
|
"size_limit": 1501560832
|
||||||
|
},
|
||||||
|
"resident_set_size_in_bytes": 286650368
|
||||||
|
},
|
||||||
|
"event_loop_delay": 0.5314235687255859,
|
||||||
|
"pid": 6,
|
||||||
|
"uptime_in_millis": 2173595336
|
||||||
|
},
|
||||||
|
"os": {
|
||||||
|
"load": {
|
||||||
|
"1m": 2.66015625,
|
||||||
|
"5m": 2.8173828125,
|
||||||
|
"15m": 2.51025390625
|
||||||
|
},
|
||||||
|
"memory": {
|
||||||
|
"total_in_bytes": 404355756032,
|
||||||
|
"free_in_bytes": 294494244864,
|
||||||
|
"used_in_bytes": 109861511168
|
||||||
|
},
|
||||||
|
"uptime_in_millis": 8220745000,
|
||||||
|
"cgroup": {
|
||||||
|
"cpuacct": {
|
||||||
|
"control_group": "/",
|
||||||
|
"usage_nanos": 1086527218898
|
||||||
|
},
|
||||||
|
"cpu": {
|
||||||
|
"control_group": "/",
|
||||||
|
"cfs_period_micros": 100000,
|
||||||
|
"cfs_quota_micros": -1,
|
||||||
|
"stat": {
|
||||||
|
"number_of_elapsed_periods": 0,
|
||||||
|
"number_of_times_throttled": 0,
|
||||||
|
"time_throttled_nanos": 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"response_times": {
|
||||||
|
"avg_in_millis": 12.5,
|
||||||
|
"max_in_millis": 123
|
||||||
|
},
|
||||||
|
"requests": {
|
||||||
|
"total": 2,
|
||||||
|
"disconnects": 0,
|
||||||
|
"status_codes": {
|
||||||
|
"200": 1,
|
||||||
|
"304": 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"concurrent_connections": 10
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
var kibanaStatusExpected6_5 = map[string]interface{}{
|
||||||
|
"status_code": 1,
|
||||||
|
"heap_total_bytes": int64(149954560),
|
||||||
|
"heap_max_bytes": int64(149954560),
|
||||||
|
"heap_used_bytes": int64(126274392),
|
||||||
|
"uptime_ms": int64(2173595336),
|
||||||
|
"response_time_avg_ms": float64(12.5),
|
||||||
|
"response_time_max_ms": int64(123),
|
||||||
|
"concurrent_connections": int64(10),
|
||||||
|
"requests_per_sec": float64(0.4),
|
||||||
|
}
|
Loading…
Reference in New Issue