Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support of snapshot in vSphere virtualmachine metricset #40683

Merged
merged 14 commits into from
Sep 6, 2024
18 changes: 18 additions & 0 deletions metricbeat/docs/fields.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -68090,6 +68090,24 @@ type: keyword
The uptime of the VM in seconds.


type: long

--

*`vsphere.virtualmachine.snapshots`*::
+
--
Deatils of the snapshots of this virtualmachine.

type: object

--

*`vsphere.virtualmachine.snapshot.count`*::
+
--
The number of snapshots of this virtualmachine.

type: long

--
Expand Down
2 changes: 1 addition & 1 deletion metricbeat/module/vsphere/fields.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions metricbeat/module/vsphere/virtualmachine/_meta/fields.yml
Original file line number Diff line number Diff line change
Expand Up @@ -91,5 +91,11 @@
type: long
description: >
The uptime of the VM in seconds.
- name: snapshots
ishleenk17 marked this conversation as resolved.
Show resolved Hide resolved
type: object
description: Deatils of the snapshots of this virtualmachine.
- name: snapshot.count
type: long
description: The number of snapshots of this virtualmachine.


5 changes: 5 additions & 0 deletions metricbeat/module/vsphere/virtualmachine/data.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,5 +72,10 @@ func (m *MetricSet) mapEvent(data VMData) mapstr.M {
if len(data.DatastoreNames) > 0 {
event["datastore.names"] = data.DatastoreNames
}
if len(data.Snapshots) > 0 {
event["snapshots"] = data.Snapshots
event["snapshot.count"] = len(data.Snapshots)
}

return event
}
21 changes: 21 additions & 0 deletions metricbeat/module/vsphere/virtualmachine/data_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,16 @@ func TestEventMapping(t *testing.T) {
"customField1": "value1",
"customField2": "value2",
},
Snapshots: []VMSnapshotData{
{
Name: "Snapshot_1",
Description: "Test snapshot 1",
},
{
Name: "Snapshot_2",
Description: "Test snapshot 2",
ishleenk17 marked this conversation as resolved.
Show resolved Hide resolved
},
},
}

event := m.mapEvent(data)
Expand Down Expand Up @@ -108,6 +118,17 @@ func TestEventMapping(t *testing.T) {
"network.names": []string{"network-1", "network-2"},
"network_names": []string{"network-1", "network-2"},
"datastore.names": []string{"ds1", "ds2"},
"snapshots": []VMSnapshotData{
{
Name: "Snapshot_1",
Description: "Test snapshot 1",
},
{
Name: "Snapshot_2",
Description: "Test snapshot 2",
},
},
"snapshot.count": 2,
}

// Assert that the output event matches the expected event
Expand Down
31 changes: 31 additions & 0 deletions metricbeat/module/vsphere/virtualmachine/virtualmachine.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import (
"errors"
"fmt"
"strings"
"time"

"github.com/elastic/beats/v7/metricbeat/mb"
"github.com/elastic/beats/v7/metricbeat/module/vsphere"
Expand Down Expand Up @@ -56,6 +57,13 @@ type VMData struct {
NetworkNames []string
DatastoreNames []string
CustomFields mapstr.M
Snapshots []VMSnapshotData
}

type VMSnapshotData struct {
Name string
Description string
CreateTime time.Time
}

// New creates a new instance of the MetricSet.
Expand Down Expand Up @@ -136,6 +144,7 @@ func (m *MetricSet) Fetch(ctx context.Context, reporter mb.ReporterV2) error {
var hostID, hostName string
var networkNames, datastoreNames []string
var customFields mapstr.M
var snapshots []VMSnapshotData

if host := vm.Summary.Runtime.Host; host != nil {
hostID = host.Value
Expand Down Expand Up @@ -179,13 +188,18 @@ func (m *MetricSet) Fetch(ctx context.Context, reporter mb.ReporterV2) error {
}
}

if vm.Snapshot != nil {
snapshots = fetchSnapshots(vm.Snapshot.RootSnapshotList)
}

data := VMData{
VM: vm,
HostID: hostID,
HostName: hostName,
NetworkNames: networkNames,
DatastoreNames: datastoreNames,
CustomFields: customFields,
Snapshots: snapshots,
}

reporter.Event(mb.Event{
Expand Down Expand Up @@ -270,3 +284,20 @@ func getHostSystem(ctx context.Context, c *vim25.Client, ref types.ManagedObject
}
return &hs, nil
}

func fetchSnapshots(snapshotTree []types.VirtualMachineSnapshotTree) []VMSnapshotData {
var snapshots []VMSnapshotData
for _, snapshot := range snapshotTree {
snapshots = append(snapshots, VMSnapshotData{
Name: snapshot.Name,
Description: snapshot.Description,
CreateTime: snapshot.CreateTime,
})

// Recursively add child snapshots
if len(snapshot.ChildSnapshotList) > 0 {
snapshots = append(snapshots, fetchSnapshots(snapshot.ChildSnapshotList)...)
}
}
return snapshots
}
Loading