2015-04-02 00:34:32 +08:00
|
|
|
package system
|
|
|
|
|
|
2015-09-01 04:03:38 +08:00
|
|
|
import (
|
2015-11-16 04:46:01 +08:00
|
|
|
"bufio"
|
|
|
|
|
"bytes"
|
|
|
|
|
"fmt"
|
2018-04-19 07:55:18 +08:00
|
|
|
"os"
|
2017-08-17 03:05:46 +08:00
|
|
|
"strings"
|
2018-04-28 05:55:10 +08:00
|
|
|
"time"
|
2015-11-16 04:46:01 +08:00
|
|
|
|
2016-01-28 05:21:36 +08:00
|
|
|
"github.com/influxdata/telegraf"
|
2016-01-21 02:57:35 +08:00
|
|
|
"github.com/influxdata/telegraf/plugins/inputs"
|
2019-08-07 06:55:06 +08:00
|
|
|
"github.com/shirou/gopsutil/cpu"
|
2019-04-11 08:19:29 +08:00
|
|
|
"github.com/shirou/gopsutil/host"
|
|
|
|
|
"github.com/shirou/gopsutil/load"
|
2015-09-01 04:03:38 +08:00
|
|
|
)
|
|
|
|
|
|
2019-09-24 06:39:50 +08:00
|
|
|
type SystemStats struct {
|
|
|
|
|
Log telegraf.Logger
|
|
|
|
|
}
|
2015-05-19 03:15:15 +08:00
|
|
|
|
2019-09-24 06:39:50 +08:00
|
|
|
func (*SystemStats) Description() string {
|
2015-09-01 04:03:38 +08:00
|
|
|
return "Read metrics about system load & uptime"
|
2015-05-19 06:10:11 +08:00
|
|
|
}
|
|
|
|
|
|
2019-09-24 06:39:50 +08:00
|
|
|
func (*SystemStats) SampleConfig() string {
|
2019-04-11 08:19:29 +08:00
|
|
|
return `
|
|
|
|
|
## Uncomment to remove deprecated metrics.
|
|
|
|
|
# fielddrop = ["uptime_format"]
|
|
|
|
|
`
|
|
|
|
|
}
|
2015-05-19 06:10:11 +08:00
|
|
|
|
2019-09-24 06:39:50 +08:00
|
|
|
func (s *SystemStats) Gather(acc telegraf.Accumulator) error {
|
2016-05-19 22:05:08 +08:00
|
|
|
loadavg, err := load.Avg()
|
2017-08-17 03:05:46 +08:00
|
|
|
if err != nil && !strings.Contains(err.Error(), "not implemented") {
|
2015-09-01 04:03:38 +08:00
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2019-08-07 06:55:06 +08:00
|
|
|
numCPUs, err := cpu.Counts(true)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2018-04-19 07:55:18 +08:00
|
|
|
fields := map[string]interface{}{
|
|
|
|
|
"load1": loadavg.Load1,
|
|
|
|
|
"load5": loadavg.Load5,
|
|
|
|
|
"load15": loadavg.Load15,
|
2019-08-07 06:55:06 +08:00
|
|
|
"n_cpus": numCPUs,
|
2015-04-07 07:03:09 +08:00
|
|
|
}
|
|
|
|
|
|
2016-03-10 00:22:34 +08:00
|
|
|
users, err := host.Users()
|
2018-04-19 07:55:18 +08:00
|
|
|
if err == nil {
|
|
|
|
|
fields["n_users"] = len(users)
|
2019-06-25 09:48:07 +08:00
|
|
|
} else if os.IsNotExist(err) {
|
2019-09-24 06:39:50 +08:00
|
|
|
s.Log.Debugf("Reading users: %s", err.Error())
|
2019-06-25 09:48:07 +08:00
|
|
|
} else if os.IsPermission(err) {
|
2019-09-24 06:39:50 +08:00
|
|
|
s.Log.Debug(err.Error())
|
2018-04-19 07:55:18 +08:00
|
|
|
}
|
|
|
|
|
|
2018-04-28 05:55:10 +08:00
|
|
|
now := time.Now()
|
|
|
|
|
acc.AddGauge("system", fields, nil, now)
|
2018-04-19 07:55:18 +08:00
|
|
|
|
2019-03-19 02:07:44 +08:00
|
|
|
uptime, err := host.Uptime()
|
2016-03-10 00:22:34 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-01 00:27:37 +08:00
|
|
|
acc.AddCounter("system", map[string]interface{}{
|
2019-03-19 02:07:44 +08:00
|
|
|
"uptime": uptime,
|
2018-04-28 05:55:10 +08:00
|
|
|
}, nil, now)
|
2017-12-14 03:13:56 +08:00
|
|
|
acc.AddFields("system", map[string]interface{}{
|
2019-03-19 02:07:44 +08:00
|
|
|
"uptime_format": formatUptime(uptime),
|
2018-04-28 05:55:10 +08:00
|
|
|
}, nil, now)
|
2015-05-19 03:15:15 +08:00
|
|
|
|
2015-04-07 00:32:10 +08:00
|
|
|
return nil
|
2015-04-02 00:34:32 +08:00
|
|
|
}
|
|
|
|
|
|
2019-03-19 02:07:44 +08:00
|
|
|
func formatUptime(uptime uint64) string {
|
2015-11-16 04:46:01 +08:00
|
|
|
buf := new(bytes.Buffer)
|
|
|
|
|
w := bufio.NewWriter(buf)
|
|
|
|
|
|
|
|
|
|
days := uptime / (60 * 60 * 24)
|
|
|
|
|
|
|
|
|
|
if days != 0 {
|
|
|
|
|
s := ""
|
|
|
|
|
if days > 1 {
|
|
|
|
|
s = "s"
|
|
|
|
|
}
|
2021-04-09 00:43:39 +08:00
|
|
|
// This will always succeed, so skip checking the error
|
|
|
|
|
//nolint:errcheck,revive
|
2015-11-16 04:46:01 +08:00
|
|
|
fmt.Fprintf(w, "%d day%s, ", days, s)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
minutes := uptime / 60
|
|
|
|
|
hours := minutes / 60
|
|
|
|
|
hours %= 24
|
|
|
|
|
minutes %= 60
|
|
|
|
|
|
2021-04-09 00:43:39 +08:00
|
|
|
// This will always succeed, so skip checking the error
|
|
|
|
|
//nolint:errcheck,revive
|
2015-11-16 04:46:01 +08:00
|
|
|
fmt.Fprintf(w, "%2d:%02d", hours, minutes)
|
|
|
|
|
|
2021-04-09 00:43:39 +08:00
|
|
|
// This will always succeed, so skip checking the error
|
|
|
|
|
//nolint:errcheck,revive
|
2015-11-16 04:46:01 +08:00
|
|
|
w.Flush()
|
|
|
|
|
return buf.String()
|
|
|
|
|
}
|
|
|
|
|
|
2015-04-02 00:34:32 +08:00
|
|
|
func init() {
|
2016-01-28 05:21:36 +08:00
|
|
|
inputs.Add("system", func() telegraf.Input {
|
2015-09-01 04:03:38 +08:00
|
|
|
return &SystemStats{}
|
2015-04-02 00:34:32 +08:00
|
|
|
})
|
|
|
|
|
}
|