1
0
mirror of https://github.com/shirou/gopsutil.git synced 2025-04-24 13:48:56 +08:00
shirou_gopsutil/load/load_linux.go

129 lines
2.6 KiB
Go
Raw Normal View History

// SPDX-License-Identifier: BSD-3-Clause
2021-12-22 21:54:41 +00:00
//go:build linux
2014-04-18 16:34:47 +09:00
2014-12-30 22:09:05 +09:00
package load
2014-04-18 16:34:47 +09:00
import (
2017-12-31 15:25:49 +09:00
"context"
"os"
2014-04-18 16:34:47 +09:00
"strconv"
"strings"
"syscall"
"github.com/shirou/gopsutil/v4/internal/common"
2014-04-18 16:34:47 +09:00
)
func Avg() (*AvgStat, error) {
2017-12-31 15:25:49 +09:00
return AvgWithContext(context.Background())
}
func AvgWithContext(ctx context.Context) (*AvgStat, error) {
stat, err := fileAvgWithContext(ctx)
if err != nil {
2021-12-22 19:53:14 +01:00
stat, err = sysinfoAvgWithContext()
}
return stat, err
}
2021-12-22 19:53:14 +01:00
func sysinfoAvgWithContext() (*AvgStat, error) {
var info syscall.Sysinfo_t
err := syscall.Sysinfo(&info)
if err != nil {
return nil, err
}
const si_load_shift = 16
return &AvgStat{
Load1: float64(info.Loads[0]) / float64(1<<si_load_shift),
Load5: float64(info.Loads[1]) / float64(1<<si_load_shift),
Load15: float64(info.Loads[2]) / float64(1<<si_load_shift),
}, nil
}
func fileAvgWithContext(ctx context.Context) (*AvgStat, error) {
values, err := readLoadAvgFromFile(ctx)
2014-04-18 16:34:47 +09:00
if err != nil {
return nil, err
2014-04-18 16:34:47 +09:00
}
load1, err := strconv.ParseFloat(values[0], 64)
if err != nil {
return nil, err
2014-04-18 16:34:47 +09:00
}
load5, err := strconv.ParseFloat(values[1], 64)
if err != nil {
return nil, err
2014-04-18 16:34:47 +09:00
}
load15, err := strconv.ParseFloat(values[2], 64)
if err != nil {
return nil, err
2014-04-18 16:34:47 +09:00
}
ret := &AvgStat{
2014-04-18 16:34:47 +09:00
Load1: load1,
Load5: load5,
Load15: load15,
}
return ret, nil
}
2022-01-30 22:48:09 +02:00
// Misc returns miscellaneous host-wide statistics.
2016-02-20 23:17:20 +09:00
// Note: the name should be changed near future.
func Misc() (*MiscStat, error) {
2017-12-31 15:25:49 +09:00
return MiscWithContext(context.Background())
}
func MiscWithContext(ctx context.Context) (*MiscStat, error) {
filename := common.HostProcWithContext(ctx, "stat")
out, err := os.ReadFile(filename)
if err != nil {
return nil, err
}
2016-02-20 23:03:32 +09:00
ret := &MiscStat{}
lines := strings.Split(string(out), "\n")
for _, line := range lines {
fields := strings.Fields(line)
if len(fields) != 2 {
continue
}
v, err := strconv.ParseInt(fields[1], 10, 64)
if err != nil {
continue
}
switch fields[0] {
2020-07-02 11:40:58 +10:00
case "processes":
ret.ProcsCreated = int(v)
case "procs_running":
2016-02-20 23:03:32 +09:00
ret.ProcsRunning = int(v)
case "procs_blocked":
2016-02-20 23:03:32 +09:00
ret.ProcsBlocked = int(v)
case "ctxt":
2016-02-20 23:03:32 +09:00
ret.Ctxt = int(v)
default:
continue
}
}
procsTotal, err := common.NumProcsWithContext(ctx)
2019-05-05 10:29:20 +08:00
if err != nil {
return ret, err
}
ret.ProcsTotal = int(procsTotal)
return ret, nil
}
2019-05-05 10:29:20 +08:00
func readLoadAvgFromFile(ctx context.Context) ([]string, error) {
loadavgFilename := common.HostProcWithContext(ctx, "loadavg")
line, err := os.ReadFile(loadavgFilename)
2019-05-05 10:29:20 +08:00
if err != nil {
return nil, err
}
values := strings.Fields(string(line))
return values, nil
}