mirror of
https://github.com/prometheus/node_exporter.git
synced 2025-01-20 15:29:00 +01:00
Merge pull request #241 from mrwacky42/ignore-fs-types
Add flag to ignore certain filesystem types (Copy of #217)
This commit is contained in:
commit
ffd96078e0
@ -33,6 +33,7 @@ import "C"
|
|||||||
|
|
||||||
const (
|
const (
|
||||||
defIgnoredMountPoints = "^/(dev)($|/)"
|
defIgnoredMountPoints = "^/(dev)($|/)"
|
||||||
|
defIgnoredFSTypes = "^devfs$"
|
||||||
MNT_RDONLY = 0x1
|
MNT_RDONLY = 0x1
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -55,6 +56,10 @@ func (c *filesystemCollector) GetStats() (stats []filesystemStats, err error) {
|
|||||||
|
|
||||||
device := C.GoString(&mnt[i].f_mntfromname[0])
|
device := C.GoString(&mnt[i].f_mntfromname[0])
|
||||||
fstype := C.GoString(&mnt[i].f_fstypename[0])
|
fstype := C.GoString(&mnt[i].f_fstypename[0])
|
||||||
|
if c.ignoredFSTypesPattern.MatchString(fstype) {
|
||||||
|
log.Debugf("Ignoring fs type: %s", fstype)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
var ro float64
|
var ro float64
|
||||||
if (mnt[i].f_flags & MNT_RDONLY) != 0 {
|
if (mnt[i].f_flags & MNT_RDONLY) != 0 {
|
||||||
|
@ -25,6 +25,7 @@ import (
|
|||||||
|
|
||||||
// Arch-dependent implementation must define:
|
// Arch-dependent implementation must define:
|
||||||
// * defIgnoredMountPoints
|
// * defIgnoredMountPoints
|
||||||
|
// * defIgnoredFSTypes
|
||||||
// * filesystemLabelNames
|
// * filesystemLabelNames
|
||||||
// * filesystemCollector.GetStats
|
// * filesystemCollector.GetStats
|
||||||
|
|
||||||
@ -34,11 +35,17 @@ var (
|
|||||||
defIgnoredMountPoints,
|
defIgnoredMountPoints,
|
||||||
"Regexp of mount points to ignore for filesystem collector.")
|
"Regexp of mount points to ignore for filesystem collector.")
|
||||||
|
|
||||||
|
ignoredFSTypes = flag.String(
|
||||||
|
"collector.filesystem.ignored-fs-types",
|
||||||
|
defIgnoredFSTypes,
|
||||||
|
"Regexp of filesystem types to ignore for filesystem collector.")
|
||||||
|
|
||||||
filesystemLabelNames = []string{"device", "mountpoint", "fstype"}
|
filesystemLabelNames = []string{"device", "mountpoint", "fstype"}
|
||||||
)
|
)
|
||||||
|
|
||||||
type filesystemCollector struct {
|
type filesystemCollector struct {
|
||||||
ignoredMountPointsPattern *regexp.Regexp
|
ignoredMountPointsPattern *regexp.Regexp
|
||||||
|
ignoredFSTypesPattern *regexp.Regexp
|
||||||
sizeDesc, freeDesc, availDesc,
|
sizeDesc, freeDesc, availDesc,
|
||||||
filesDesc, filesFreeDesc, roDesc *prometheus.Desc
|
filesDesc, filesFreeDesc, roDesc *prometheus.Desc
|
||||||
}
|
}
|
||||||
@ -56,7 +63,8 @@ func init() {
|
|||||||
// Filesystems stats.
|
// Filesystems stats.
|
||||||
func NewFilesystemCollector() (Collector, error) {
|
func NewFilesystemCollector() (Collector, error) {
|
||||||
subsystem := "filesystem"
|
subsystem := "filesystem"
|
||||||
pattern := regexp.MustCompile(*ignoredMountPoints)
|
mountPointPattern := regexp.MustCompile(*ignoredMountPoints)
|
||||||
|
filesystemsTypesPattern := regexp.MustCompile(*ignoredFSTypes)
|
||||||
|
|
||||||
sizeDesc := prometheus.NewDesc(
|
sizeDesc := prometheus.NewDesc(
|
||||||
prometheus.BuildFQName(Namespace, subsystem, "size"),
|
prometheus.BuildFQName(Namespace, subsystem, "size"),
|
||||||
@ -95,7 +103,8 @@ func NewFilesystemCollector() (Collector, error) {
|
|||||||
)
|
)
|
||||||
|
|
||||||
return &filesystemCollector{
|
return &filesystemCollector{
|
||||||
ignoredMountPointsPattern: pattern,
|
ignoredMountPointsPattern: mountPointPattern,
|
||||||
|
ignoredFSTypesPattern: filesystemsTypesPattern,
|
||||||
sizeDesc: sizeDesc,
|
sizeDesc: sizeDesc,
|
||||||
freeDesc: freeDesc,
|
freeDesc: freeDesc,
|
||||||
availDesc: availDesc,
|
availDesc: availDesc,
|
||||||
|
@ -26,6 +26,7 @@ import (
|
|||||||
|
|
||||||
const (
|
const (
|
||||||
defIgnoredMountPoints = "^/(sys|proc|dev)($|/)"
|
defIgnoredMountPoints = "^/(sys|proc|dev)($|/)"
|
||||||
|
defIgnoredFSTypes = "^(sys|proc)fs$"
|
||||||
ST_RDONLY = 0x1
|
ST_RDONLY = 0x1
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -47,6 +48,10 @@ func (c *filesystemCollector) GetStats() (stats []filesystemStats, err error) {
|
|||||||
log.Debugf("Ignoring mount point: %s", mpd.mountPoint)
|
log.Debugf("Ignoring mount point: %s", mpd.mountPoint)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
if c.ignoredFSTypesPattern.MatchString(mpd.fsType) {
|
||||||
|
log.Debugf("Ignoring fs type: %s", mpd.fsType)
|
||||||
|
continue
|
||||||
|
}
|
||||||
buf := new(syscall.Statfs_t)
|
buf := new(syscall.Statfs_t)
|
||||||
err := syscall.Statfs(mpd.mountPoint, buf)
|
err := syscall.Statfs(mpd.mountPoint, buf)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user