Skip to content

Commit

Permalink
[vSphere] Add new resourcepool datatastream (#10996)
Browse files Browse the repository at this point in the history
* add resourcepool datastream

* Update changelog

* address review comments

* add triggered_alarm

* address review comments

* update changelog

* address review comment

* address review comment

---------

Co-authored-by: Niraj Rathod <[email protected]>
  • Loading branch information
niraj-elastic and niraj-crest authored Sep 19, 2024
1 parent bde6b51 commit 40459dc
Show file tree
Hide file tree
Showing 14 changed files with 733 additions and 94 deletions.
29 changes: 21 additions & 8 deletions packages/vsphere/_dev/build/docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,16 @@ The vSphere integration collects logs and metrics.

Logs help you keep a record of events that happen on your machine. The `Log` data stream collected by vSphere as integration is `log`.

Metrics give you insight into the statistics of the vSphere. The `Metric` data stream collected by the vSphere integration are `cluster`, `datastore`, `host` and `virtualmachine` so that the user can monitor and troubleshoot the performance of the vSphere instance.
Metrics give you insight into the statistics of the vSphere. The `Metric` data stream collected by the vSphere integration are `cluster`, `datastore`, `host`, `resourcepool` and `virtualmachine` so that the user can monitor and troubleshoot the performance of the vSphere instance.

Data streams:
- `log`: This data stream collects logs generated by VMware vSphere using a syslog daemon.
- `datastore`: This data stream collects datastore metrics from VMware vSphere, including performance statistics such as capacity, usage, read/write operations, latency, and throughput. These metrics are available in this data stream.
- `host`: This data stream collects host metrics from VMware vSphere, including performance statistics such as CPU usage, memory usage, disk I/O, and network activity. These metrics are available in this data stream.
- `virtualmachine`: This data stream collects virtual machine metrics from VMware vSphere, including performance statistics such as status, uptime, CPU usage, memory usage, and network activity. These metrics are available in this data stream.
- `cluster`: This data stream collects metrics from VMware vSphere, such as lists of datastores, hosts and networks associated with cluster.
- `datastore`: This data stream collects datastore metrics from VMware vSphere, including performance statistics such as capacity, usage, read/write operations, latency, and throughput.
- `host`: This data stream collects host metrics from VMware vSphere, including performance statistics such as CPU usage, memory usage, disk I/O, and network activity.
- `resourcepool`: This data stream collects metrics from VMware vSphere, such as CPU and memory usage, CPU and memory reservation, and CPU and memory limit.
- `virtualmachine`: This data stream collects virtual machine metrics from VMware vSphere, including performance statistics such as status, uptime, CPU usage, memory usage, and network activity.


Note:
- Users can monitor and see the log inside the ingested documents for vSphere in the `logs-*` index pattern from `Discover`, and for metrics, the index pattern is `metrics-*`.
Expand Down Expand Up @@ -70,6 +72,17 @@ Please refer to the following [document](https://www.elastic.co/guide/en/ecs/cur
Note:
- To access the metrics, provide the URL <https://host:port/sdk> in the "Add Integration" page of the vSphere package.

### Cluster Metrics
Clusters in vSphere represent a group of ESXi hosts working together to optimize resource allocation, ensure high availability, and manage workloads efficiently.

{{event "cluster"}}

**ECS Field Reference**

Please refer to the following [document](https://www.elastic.co/guide/en/ecs/current/ecs-field-reference.html) for detailed information on ECS fields.

{{fields "cluster"}}

### Datastore

This is `datastore` data stream. This data stream collects datastore metrics from VMware vSphere, including performance statistics such as capacity, usage, read/write operations, latency, and throughput.
Expand All @@ -94,16 +107,16 @@ Please refer to the following [document](https://www.elastic.co/guide/en/ecs/cur

{{fields "host"}}

### Cluster Metrics
Clusters in vSphere represent a group of ESXi hosts working together to optimize resource allocation, ensure high availability, and manage workloads efficiently.
### Resourcepool Metrics
Resource pools in vSphere allow for the allocation and management of CPU and memory resources across groups of virtual machines.

{{event "cluster"}}
{{event "resourcepool"}}

**ECS Field Reference**

Please refer to the following [document](https://www.elastic.co/guide/en/ecs/current/ecs-field-reference.html) for detailed information on ECS fields.

{{fields "cluster"}}
{{fields "resourcepool"}}

### Virtual Machine

Expand Down
3 changes: 3 additions & 0 deletions packages/vsphere/changelog.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
# newer versions go on top
- version: "1.15.0-next"
changes:
- description: Add resourcepool datastream.
type: enhancement
link: https://github.com/elastic/integrations/pull/10996
- description: Add cluster datastream.
type: enhancement
link: https://github.com/elastic/integrations/pull/10949
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
{
"events": [
{
"vsphere": {
"resourcepool": {
"status": "green",
"vm": {
"names": [
"VM_1",
"VM_2"
],
"count": 2
},
"cpu": {
"usage": {
"mhz": 3344
},
"demand": {
"mhz": 3428
},
"entitlement": {
"static": {
"mhz": 21294
},
"mhz": 3239
}
},
"memory": {
"entitlement": {
"bytes": 38854983680,
"static": {
"bytes": 13631488
}
},
"private": {
"bytes": 121667321856
},
"shared": {
"bytes": 42991616
},
"swapped": {
"bytes": 0
},
"ballooned": {
"bytes": 0
},
"overhead": {
"consumed": {
"bytes": 1001390080
},
"bytes": 1695547392
},
"compressed": {
"bytes": 0
},
"usage": {
"guest": {
"bytes": 7976517632
},
"host": {
"bytes": 122667663360
}
}
},
"name": "Resources"
}
}
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
{
"expected": [
{
"ecs": {
"version": "8.11.0"
},
"vsphere": {
"resourcepool": {
"cpu": {
"demand": {
"mhz": 3428
},
"entitlement": {
"mhz": 3239,
"static": {
"mhz": 21294
}
},
"usage": {
"mhz": 3344
}
},
"memory": {
"ballooned": {
"bytes": 0
},
"compressed": {
"bytes": 0
},
"entitlement": {
"bytes": 38854983680,
"static": {
"bytes": 13631488
}
},
"overhead": {
"bytes": 1695547392,
"consumed": {
"bytes": 1001390080
}
},
"private": {
"bytes": 121667321856
},
"shared": {
"bytes": 42991616
},
"swapped": {
"bytes": 0
},
"usage": {
"guest": {
"bytes": 7976517632
},
"host": {
"bytes": 122667663360
}
}
},
"name": "Resources",
"status": "green",
"vm": {
"count": 2,
"names": [
"VM_1",
"VM_2"
]
}
}
}
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
service: vsphere-metrics
vars:
hosts:
- "https://{{Hostname}}:8989/sdk"
period: 10s
username: "user"
password: "password"
# If insecure is true, don't verify the server's certificate chain
insecure: true
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
metricsets: ["resourcepool"]
hosts:
{{#each hosts}}
- {{this}}
{{/each}}
period: {{period}}
username: {{username}}
password: {{password}}
# If insecure is true, don't verify the server's certificate chain
insecure: {{insecure}}
tags:
{{#each tags as |tag|}}
- {{tag}}
{{/each}}
{{#if processors}}
processors:
{{processors}}
{{/if}}
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
---
description: Pipeline for resourcepool
processors:
- set:
field: ecs.version
value: '8.11.0'
on_failure:
- set:
field: error.message
value: '{{ _ingest.on_failure_message }}'
20 changes: 20 additions & 0 deletions packages/vsphere/data_stream/resourcepool/fields/agent.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
- name: host
title: Host
group: 2
description: A host is defined as a general computing instance. ECS host.* fields should be populated with details about the host on which the event happened, or from which the measurement was taken. Host types include hardware, virtual machines, Docker containers, and Kubernetes nodes.
type: group
fields:
- name: name
level: core
type: keyword
dimension: true
ignore_above: 1024
description: Name of the host. It can contain what `hostname` returns on Unix systems, the fully qualified domain name, or a name specified by the user. The sender decides which value to use.
- name: agent
title: Agent
type: group
fields:
- name: id
type: keyword
ignore_above: 1024
dimension: true
12 changes: 12 additions & 0 deletions packages/vsphere/data_stream/resourcepool/fields/base-fields.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
- name: data_stream.type
type: constant_keyword
description: Data stream type.
- name: data_stream.dataset
type: constant_keyword
description: Data stream dataset.
- name: data_stream.namespace
type: constant_keyword
description: Data stream namespace.
- name: '@timestamp'
type: date
description: Event timestamp.
21 changes: 21 additions & 0 deletions packages/vsphere/data_stream/resourcepool/fields/ecs.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
- name: service.address
external: ecs
dimension: true
- external: ecs
name: cloud.instance.id
dimension: true
- external: ecs
name: cloud.provider
dimension: true
- external: ecs
name: container.id
dimension: true
- external: ecs
name: cloud.account.id
dimension: true
- external: ecs
name: cloud.region
dimension: true
- external: ecs
name: cloud.availability_zone
dimension: true
Loading

0 comments on commit 40459dc

Please sign in to comment.