package system import ( "fmt" "github.com/influxdb/telegraf/plugins" ) type DiskStats struct { ps PS Mountpoints []string SkipInodeUsage bool } func (_ *DiskStats) Description() string { return "Read metrics about disk usage by mount point" } var diskSampleConfig = ` # By default, telegraf gather stats for all mountpoints and for inodes. # Setting mountpoints will restrict the stats to the specified ones. # mountpoints. # Mountpoints=["/"] # Setting SkipInodeUsage will skip the reporting of inode stats. # SkipInodeUsage=true ` func (_ *DiskStats) SampleConfig() string { return diskSampleConfig } func (s *DiskStats) Gather(acc plugins.Accumulator) error { disks, err := s.ps.DiskUsage() if err != nil { return fmt.Errorf("error getting disk usage info: %s", err) } mPoints := make(map[string]bool) for _, mp := range s.Mountpoints { mPoints[mp] = true } for _, du := range disks { _, member := mPoints[ du.Path ] if !member { continue } tags := map[string]string{ "path": du.Path, "fstype": du.Fstype, } acc.Add("total", du.Total, tags) acc.Add("free", du.Free, tags) acc.Add("used", du.Total-du.Free, tags) if !s.SkipInodeUsage { acc.Add("inodes_total", du.InodesTotal, tags) acc.Add("inodes_free", du.InodesFree, tags) acc.Add("inodes_used", du.InodesTotal-du.InodesFree, tags) } } return nil } type DiskIOStats struct { ps PS } func (_ *DiskIOStats) Description() string { return "Read metrics about disk IO by device" } func (_ *DiskIOStats) SampleConfig() string { return "" } func (s *DiskIOStats) Gather(acc plugins.Accumulator) error { diskio, err := s.ps.DiskIO() if err != nil { return fmt.Errorf("error getting disk io info: %s", err) } for _, io := range diskio { tags := map[string]string{} if len(io.Name) != 0 { tags["name"] = io.Name } if len(io.SerialNumber) != 0 { tags["serial"] = io.SerialNumber } acc.Add("reads", io.ReadCount, tags) acc.Add("writes", io.WriteCount, tags) acc.Add("read_bytes", io.ReadBytes, tags) acc.Add("write_bytes", io.WriteBytes, tags) acc.Add("read_time", io.ReadTime, tags) acc.Add("write_time", io.WriteTime, tags) acc.Add("io_time", io.IoTime, tags) } return nil } func init() { plugins.Add("disk", func() plugins.Plugin { return &DiskStats{ps: &systemPS{}} }) plugins.Add("io", func() plugins.Plugin { return &DiskIOStats{ps: &systemPS{}} }) }