mem_linux: VirtualMemory() is now from /proc/meminfo, not syscall.
This commit is contained in:
parent
879127682b
commit
c78563d5dd
47
mem_linux.go
47
mem_linux.go
|
@ -3,35 +3,44 @@
|
||||||
package gopsutil
|
package gopsutil
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"strings"
|
||||||
"syscall"
|
"syscall"
|
||||||
)
|
)
|
||||||
|
|
||||||
func VirtualMemory() (*VirtualMemoryStat, error) {
|
func VirtualMemory() (*VirtualMemoryStat, error) {
|
||||||
sysinfo := &syscall.Sysinfo_t{}
|
filename := "/proc/meminfo"
|
||||||
|
lines, _ := readLines(filename)
|
||||||
|
|
||||||
if err := syscall.Sysinfo(sysinfo); err != nil {
|
ret := &VirtualMemoryStat{}
|
||||||
return nil, err
|
for _, line := range lines {
|
||||||
|
fields := strings.Split(line, ":")
|
||||||
|
if len(fields) != 2 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
key := strings.TrimSpace(fields[0])
|
||||||
|
value := strings.TrimSpace(fields[1])
|
||||||
|
value = strings.Replace(value, " kB", "", -1)
|
||||||
|
|
||||||
|
switch key {
|
||||||
|
case "MemTotal":
|
||||||
|
ret.Total = mustParseUint64(value)
|
||||||
|
case "MemFree":
|
||||||
|
ret.Free = mustParseUint64(value)
|
||||||
|
case "Buffers":
|
||||||
|
ret.Buffers = mustParseUint64(value)
|
||||||
|
case "Cached":
|
||||||
|
ret.Cached = mustParseUint64(value)
|
||||||
|
case "Active":
|
||||||
|
ret.Active = mustParseUint64(value)
|
||||||
|
case "Inactive":
|
||||||
|
ret.Inactive = mustParseUint64(value)
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ret := &VirtualMemoryStat{
|
|
||||||
Total: uint64(sysinfo.Totalram),
|
|
||||||
Free: uint64(sysinfo.Freeram),
|
|
||||||
Shared: uint64(sysinfo.Sharedram),
|
|
||||||
Buffers: uint64(sysinfo.Bufferram),
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: platform independent
|
|
||||||
ret.Available = ret.Free + ret.Buffers + ret.Cached
|
ret.Available = ret.Free + ret.Buffers + ret.Cached
|
||||||
|
|
||||||
ret.Used = ret.Total - ret.Free
|
ret.Used = ret.Total - ret.Free
|
||||||
ret.UsedPercent = float64(ret.Total-ret.Available) / float64(ret.Total) * 100.0
|
ret.UsedPercent = float64(ret.Total-ret.Available) / float64(ret.Total) * 100.0
|
||||||
|
|
||||||
/*
|
|
||||||
kern := buffers + cached
|
|
||||||
ret.ActualFree = ret.Free + kern
|
|
||||||
ret.ActualUsed = ret.Used - kern
|
|
||||||
*/
|
|
||||||
|
|
||||||
return ret, nil
|
return ret, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue