mirror of
https://github.com/Oxalide/vsphere-influxdb-go.git
synced 2023-10-10 13:36:51 +02:00
add datastore capacity and free
This commit is contained in:
parent
d62d5bf1ac
commit
ce1d72055f
@ -221,6 +221,7 @@ func (vcenter *VCenter) Query(config Configuration, InfluxDBClient influxclient.
|
|||||||
}
|
}
|
||||||
objectTypes = append(objectTypes, "ClusterComputeResource")
|
objectTypes = append(objectTypes, "ClusterComputeResource")
|
||||||
objectTypes = append(objectTypes, "ResourcePool")
|
objectTypes = append(objectTypes, "ResourcePool")
|
||||||
|
objectTypes = append(objectTypes, "Datastore")
|
||||||
|
|
||||||
// Loop trought datacenters and create the intersting object reference list
|
// Loop trought datacenters and create the intersting object reference list
|
||||||
mors := []types.ManagedObjectReference{}
|
mors := []types.ManagedObjectReference{}
|
||||||
@ -250,6 +251,7 @@ func (vcenter *VCenter) Query(config Configuration, InfluxDBClient influxclient.
|
|||||||
hostRefs := []types.ManagedObjectReference{}
|
hostRefs := []types.ManagedObjectReference{}
|
||||||
clusterRefs := []types.ManagedObjectReference{}
|
clusterRefs := []types.ManagedObjectReference{}
|
||||||
respoolRefs := []types.ManagedObjectReference{}
|
respoolRefs := []types.ManagedObjectReference{}
|
||||||
|
datastoreRefs := []types.ManagedObjectReference{}
|
||||||
|
|
||||||
newMors := []types.ManagedObjectReference{}
|
newMors := []types.ManagedObjectReference{}
|
||||||
|
|
||||||
@ -268,7 +270,9 @@ func (vcenter *VCenter) Query(config Configuration, InfluxDBClient influxclient.
|
|||||||
clusterRefs = append(clusterRefs, mor)
|
clusterRefs = append(clusterRefs, mor)
|
||||||
} else if mor.Type == "ResourcePool" {
|
} else if mor.Type == "ResourcePool" {
|
||||||
respoolRefs = append(respoolRefs, mor)
|
respoolRefs = append(respoolRefs, mor)
|
||||||
}
|
} else if mor.Type == "Datastore" {
|
||||||
|
datastoreRefs = append(datastoreRefs, mor)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy the mors without the clusters
|
// Copy the mors without the clusters
|
||||||
@ -307,6 +311,14 @@ func (vcenter *VCenter) Query(config Configuration, InfluxDBClient influxclient.
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Retrieve summary property for all datastores
|
||||||
|
var dss []mo.Datastore
|
||||||
|
err = pc.Retrieve(ctx, datastoreRefs, []string{"summary"}, &dss)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// Initialize the map that will hold the VM MOR to ResourcePool reference
|
// Initialize the map that will hold the VM MOR to ResourcePool reference
|
||||||
vmToPool := make(map[types.ManagedObjectReference]string)
|
vmToPool := make(map[types.ManagedObjectReference]string)
|
||||||
|
|
||||||
@ -640,6 +652,20 @@ func (vcenter *VCenter) Query(config Configuration, InfluxDBClient influxclient.
|
|||||||
bp.AddPoint(pt3)
|
bp.AddPoint(pt3)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for _, datastore := range dss {
|
||||||
|
datastoreFields := map[string]interface{}{
|
||||||
|
"capacity": datastore.Summary.Capacity,
|
||||||
|
"free_space": datastore.Summary.FreeSpace,
|
||||||
|
}
|
||||||
|
datastoreTags := map[string]string{"ds_name": datastore.Summary.Name}
|
||||||
|
pt4, err := influxclient.NewPoint("datastore", datastoreTags, datastoreFields, time.Now())
|
||||||
|
if err != nil {
|
||||||
|
errlog.Println(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
bp.AddPoint(pt4)
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//InfluxDB send
|
//InfluxDB send
|
||||||
|
@ -64,6 +64,13 @@
|
|||||||
{ "Metric": "disk.numberWriteAveraged.average", "Instances": "*" },
|
{ "Metric": "disk.numberWriteAveraged.average", "Instances": "*" },
|
||||||
{ "Metric": "net.throughput.contention.summation", "Instances": "*" }
|
{ "Metric": "net.throughput.contention.summation", "Instances": "*" }
|
||||||
]
|
]
|
||||||
}
|
},
|
||||||
|
{
|
||||||
|
"ObjectType": [ "Datastore" ],
|
||||||
|
"Definition": [
|
||||||
|
{ "Metric": "disk.capacity.latest", "Instances": "*" },
|
||||||
|
{ "Metric": "disk.used.latest", "Instances": "*" }
|
||||||
|
]
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user