Bug 1434575 - [RFE] Update engine and hosts fluentd configurations to use rubygem-fluent-plugin-collectd-nest
Summary: [RFE] Update engine and hosts fluentd configurations to use rubygem-fluent-pl...
Keywords:
Status: CLOSED CURRENTRELEASE
Alias: None
Product: ovirt-engine-metrics
Classification: oVirt
Component: RFEs
Version: 1.0.0
Hardware: Unspecified
OS: Unspecified
unspecified
high
Target Milestone: ovirt-4.1.3
: 1.0.4.1
Assignee: Shirly Radco
QA Contact: Lukas Svaty
URL:
Whiteboard:
Depends On: 1426897 1426901 1426903 1426904
Blocks: oVirt-Metrics-and-Logs 1456459
TreeView+ depends on / blocked
 
Reported: 2017-03-21 19:49 UTC by Shirly Radco
Modified: 2017-07-06 13:12 UTC (History)
6 users (show)

Fixed In Version:
Doc Type: Enhancement
Doc Text:
Clone Of:
Environment:
Last Closed: 2017-07-06 13:12:38 UTC
oVirt Team: Metrics
Embargoed:
rule-engine: ovirt-4.1+
ylavi: planning_ack+
rule-engine: devel_ack+
lsvaty: testing_ack+


Attachments (Terms of Use)


Links
System ID Private Priority Status Summary Last Updated
oVirt gerrit 74070 0 master MERGED fluentd:update hosts and engine to use nest plugin 2017-06-01 08:54:22 UTC
oVirt gerrit 74464 0 master MERGED collectd: load postgresql plugin on engine machine 2017-03-21 19:57:05 UTC

Description Shirly Radco 2017-03-21 19:49:48 UTC
Description of problem:
The  rubygem-fluent-plugin-collectd-nest is required to formats Fluentd records in the proper ViaQ data model. We need to update the engine and hosts fluentd confs file to use it.

Comment 1 Lukas Svaty 2017-03-30 12:17:41 UTC
Please provide verification steps for this one.

Comment 2 Shirly Radco 2017-06-20 13:27:51 UTC
Steps to reproduce:

1. Set up metrics on the engine and hosts
2. Check the records in Kibana - 
     The plugin converts collectd fields to be nested under "collectd".
     The numeric value of the record is nested under "collectd"-> "plugin" -> "type". 
     A record can have one or more numeric values.

Previously this was done not in a dedicated plugin but in the config file.

Examples of expected results:

"collectd": {
      "interval": 10,
      "plugin": "processes",
      "type": "ps_state",
      "type_instance": "sleeping",
      "processes": {
        "ps_state": 272
      }
    }, 

"collectd": {
      "interval": 10,
      "plugin": "disk",
      "plugin_instance": "sda",
      "type": "disk_octets",
      "disk": {
        "disk_octets": {
          "read": 0,
          "write": 1899692.00845666
        }
      }

Comment 3 Lukas Svaty 2017-06-20 14:50:43 UTC
(In reply to Shirly Radco from comment #2)
> Steps to reproduce:
> 
> 1. Set up metrics on the engine and hosts
> 2. Check the records in Kibana - 
>      The plugin converts collectd fields to be nested under "collectd".
>      The numeric value of the record is nested under "collectd"-> "plugin"
> -> "type". 
You sure about this?
>      A record can have one or more numeric values.
> 
> Previously this was done not in a dedicated plugin but in the config file.
> 
> Examples of expected results:
> 
> "collectd": {
>       "interval": 10,
>       "plugin": "processes",
>       "type": "ps_state",
>       "type_instance": "sleeping",
>       "processes": {
>         "ps_state": 272
IIUC this is under collectd->processes->ps_state and not collectd->plugin->type
>       }
>     }, 
> 
> "collectd": {
>       "interval": 10,
>       "plugin": "disk",
>       "plugin_instance": "sda",
>       "type": "disk_octets",
>       "disk": {
>         "disk_octets": {
>           "read": 0,
>           "write": 1899692.00845666

IIUC this is under collectd->disk->disk_octets->write and not collectd->plugin->type
>         }
>       }

Thus what am I really looking for, the data are indeed nested under collectd however does not fit your specification

example output on my machine:

{
  "_index": "ovirt-metrics-2017.06.20",
  "_type": "fluentd",
  "_id": "AVzEtQeqCiT5_6MSsdhE",
  "_score": 1,
  "_source": {
    "hostname": "******************************",
    "collectd": {
      "dstypes": [
        "gauge"
      ],
      "interval": 10,
      "plugin": "memory",
      "type": "memory",
      "type_instance": "buffered",
      "memory": {
        "memory": 2195456
      }
    },
    "tag": "project.ovirt-metrics-engine",
    "ovirt": {
      "entity": "engine"
    },
    "ipaddr4": "***********",
    "ipaddr6": "*****************************",
    "@timestamp": "2017-06-20T10:35:49+02:00"
  }
}

Is this correct they are nested under collectd?
What did you mean by 'The numeric value of the record is nested under "collectd"-> "plugin" -> "type".'?

Comment 4 Shirly Radco 2017-06-21 05:46:36 UTC
This is ok.
This means the field name is built as 

"collectd" 
    { "memory"(plugin_field) 
        { "memory" (type_field) :2195456
        }
    }

Comment 5 Lukas Svaty 2017-06-21 07:27:02 UTC
I see, thank you, due to comment #3 and #4 moving to verified


Note You need to log in before you can comment on or make changes to this bug.