From 06224d17a989edf7050aec67828a021b49730517 Mon Sep 17 00:00:00 2001 From: Perry Ross Date: Mon, 3 Aug 2020 16:15:32 -0600 Subject: [PATCH] Add support for new balloon memory stats Change-Id: I17e8ee7edd19287c1b448467481229ae1cc554e6 --- collectors/domain_stats.go | 158 ++++++++++++++++++++++++++++++++++++- go.mod | 2 +- 2 files changed, 157 insertions(+), 3 deletions(-) diff --git a/collectors/domain_stats.go b/collectors/domain_stats.go index f3e9c46..1091258 100644 --- a/collectors/domain_stats.go +++ b/collectors/domain_stats.go @@ -40,8 +40,19 @@ type DomainStatsCollector struct { DomainCPUUser *prometheus.Desc DomainCPUSystem *prometheus.Desc - DomainBalloonCurrent *prometheus.Desc - DomainBalloonMaximum *prometheus.Desc + DomainBalloonCurrent *prometheus.Desc + DomainBalloonMaximum *prometheus.Desc + DomainBalloonSwapIn *prometheus.Desc + DomainBalloonSwapOut *prometheus.Desc + DomainBalloonMajorFault *prometheus.Desc + DomainBalloonMinorFault *prometheus.Desc + DomainBalloonUnused *prometheus.Desc + DomainBalloonAvailable *prometheus.Desc + DomainBalloonRss *prometheus.Desc + DomainBalloonUsable *prometheus.Desc + DomainBalloonDiskCaches *prometheus.Desc + DomainBalloonHugetlbPgAlloc *prometheus.Desc + DomainBalloonHugetlbPgFail *prometheus.Desc DomainVcpuState *prometheus.Desc DomainVcpuTime *prometheus.Desc @@ -134,6 +145,61 @@ func NewDomainStatsCollector(nova bool, libvirtURI string) (*DomainStatsCollecto "the maximum memory in kiB allowed", []string{"uuid"}, nil, ), + DomainBalloonSwapIn: prometheus.NewDesc( + "libvirtd_domain_balloon_swap_in", + "kiB of memory swapped in", + []string{"uuid"}, nil, + ), + DomainBalloonSwapOut: prometheus.NewDesc( + "libvirtd_domain_balloon_swap_out", + "kiB of memory swapped out", + []string{"uuid"}, nil, + ), + DomainBalloonMajorFault: prometheus.NewDesc( + "libvirtd_domain_balloon_major_fault", + "number of page faults where disk I/O was required", + []string{"uuid"}, nil, + ), + DomainBalloonMinorFault: prometheus.NewDesc( + "libvirtd_domain_balloon_minor_fault", + "number of page faults where disk I/O was not required", + []string{"uuid"}, nil, + ), + DomainBalloonUnused: prometheus.NewDesc( + "libvirtd_domain_balloon_unused", + "KiB of memory left unused by the system", + []string{"uuid"}, nil, + ), + DomainBalloonAvailable: prometheus.NewDesc( + "libvirtd_domain_balloon_available", + "KiB of memory usable by the domain", + []string{"uuid"}, nil, + ), + DomainBalloonRss: prometheus.NewDesc( + "libvirtd_domain_balloon_rss", + "resident set size of domain in KiB", + []string{"uuid"}, nil, + ), + DomainBalloonUsable: prometheus.NewDesc( + "libvirtd_domain_balloon_usable", + "KiB of memory that can be reclaimed without swapping", + []string{"uuid"}, nil, + ), + DomainBalloonDiskCaches: prometheus.NewDesc( + "libvirtd_domain_balloon_disk_caches", + "KiB of memory used by disk caches", + []string{"uuid"}, nil, + ), + DomainBalloonHugetlbPgAlloc: prometheus.NewDesc( + "libvirtd_domain_balloon_hugetlb_pgalloc", + "number of successful huge page allocations done by virtio balloon", + []string{"uuid"}, nil, + ), + DomainBalloonHugetlbPgFail: prometheus.NewDesc( + "libvirtd_domain_balloon_hugetlb_pgfail", + "number of failed huge page allocations done by virtio balloon", + []string{"uuid"}, nil, + ), DomainVcpuState: prometheus.NewDesc( "libvirtd_domain_vcpu_state", @@ -275,6 +341,17 @@ func (c *DomainStatsCollector) describeCPU(ch chan<- *prometheus.Desc) { func (c *DomainStatsCollector) describeBalloon(ch chan<- *prometheus.Desc) { ch <- c.DomainBalloonCurrent ch <- c.DomainBalloonMaximum + ch <- c.DomainBalloonSwapIn + ch <- c.DomainBalloonSwapOut + ch <- c.DomainBalloonMajorFault + ch <- c.DomainBalloonMinorFault + ch <- c.DomainBalloonUnused + ch <- c.DomainBalloonAvailable + ch <- c.DomainBalloonRss + ch <- c.DomainBalloonUsable + ch <- c.DomainBalloonDiskCaches + ch <- c.DomainBalloonHugetlbPgAlloc + ch <- c.DomainBalloonHugetlbPgFail } func (c *DomainStatsCollector) describeVcpu(ch chan<- *prometheus.Desc) { @@ -404,6 +481,83 @@ func (c *DomainStatsCollector) collectBalloon(uuid string, stat libvirt.DomainSt prometheus.GaugeValue, float64(stat.Balloon.Maximum), uuid, ) + if stat.Balloon.SwapInSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonSwapIn, + prometheus.CounterValue, + float64(stat.Balloon.SwapIn), uuid, + ) + } + if stat.Balloon.SwapOutSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonSwapOut, + prometheus.CounterValue, + float64(stat.Balloon.SwapOut), uuid, + ) + } + if stat.Balloon.MajorFaultSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonMajorFault, + prometheus.CounterValue, + float64(stat.Balloon.MajorFault), uuid, + ) + } + if stat.Balloon.MinorFaultSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonMinorFault, + prometheus.CounterValue, + float64(stat.Balloon.MinorFault), uuid, + ) + } + if stat.Balloon.UnusedSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonUnused, + prometheus.GaugeValue, + float64(stat.Balloon.Unused), uuid, + ) + } + if stat.Balloon.AvailableSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonAvailable, + prometheus.GaugeValue, + float64(stat.Balloon.Available), uuid, + ) + } + if stat.Balloon.RssSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonRss, + prometheus.GaugeValue, + float64(stat.Balloon.Rss), uuid, + ) + } + if stat.Balloon.UsableSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonUsable, + prometheus.GaugeValue, + float64(stat.Balloon.Usable), uuid, + ) + } + if stat.Balloon.DiskCachesSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonDiskCaches, + prometheus.GaugeValue, + float64(stat.Balloon.DiskCaches), uuid, + ) + } + if stat.Balloon.HugetlbPgAllocSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonHugetlbPgAlloc, + prometheus.CounterValue, + float64(stat.Balloon.HugetlbPgAlloc), uuid, + ) + } + if stat.Balloon.HugetlbPgFailSet { + ch <- prometheus.MustNewConstMetric( + c.DomainBalloonHugetlbPgFail, + prometheus.CounterValue, + float64(stat.Balloon.HugetlbPgFail), uuid, + ) + } } func (c *DomainStatsCollector) collectVcpu(uuid string, stat libvirt.DomainStats, ch chan<- prometheus.Metric) { diff --git a/go.mod b/go.mod index 44e8315..8d03360 100644 --- a/go.mod +++ b/go.mod @@ -3,7 +3,7 @@ module opendev.org/vexxhost/libvirtd_exporter go 1.13 require ( - github.com/libvirt/libvirt-go v5.10.0+incompatible + github.com/libvirt/libvirt-go v6.6.0+incompatible github.com/prometheus/client_golang v1.0.0 github.com/prometheus/common v0.7.0 gopkg.in/alecthomas/kingpin.v2 v2.2.6