- morning := time.Now()
- elapsed := morning.Sub(bedtime).Seconds()
- cpuset_cpus := FindStat(stderr, cgroup, "cpuset", "cpuset.cpus")
- if cpuset_cpus != "" {
- b, err := OpenAndReadAll(cpuset_cpus, stderr)
- if err != nil {
- // cgroup probably gone -- skip other stats too.
- continue
- }
- sp := strings.Split(string(b), ",")
- cpus := int64(0)
- for _, v := range sp {
- var min, max int64
- n, _ := fmt.Sscanf(v, "%d-%d", &min, &max)
- if n == 2 {
- cpus += (max - min) + 1
- } else {
- cpus += 1
- }
- }
- last_cpucount = cpus
- }
- cpuacct_stat := FindStat(stderr, cgroup, "cpuacct", "cpuacct.stat")
- if cpuacct_stat != "" {
- b, err := OpenAndReadAll(cpuacct_stat, stderr)
- if err != nil {
- // Next time around, last_user would
- // be >1 interval old, so stats will
- // be incorrect. Start over instead.
- last_user = -1
-
- // cgroup probably gone -- skip other stats too.
- continue
- }
- var next_user int64
- var next_sys int64
- fmt.Sscanf(string(b), "user %d\nsystem %d", &next_user, &next_sys)
-
- delta := ""
- if elapsed > 0 && last_user != -1 {
- delta = fmt.Sprintf(" -- interval %.4f seconds %.4f user %.4f sys",
- elapsed,
- float64(next_user - last_user) / user_hz,
- float64(next_sys - last_sys) / user_hz)
- }
- stderr <- fmt.Sprintf("crunchstat: cpu %.4f user %.4f sys %d cpus%s",
- float64(next_user) / user_hz,
- float64(next_sys) / user_hz,
- last_cpucount,
- delta)
- last_user = next_user
- last_sys = next_sys
- }
-
- DoBlkIoStats(stderr, cgroup)
- DoMemoryStats(stderr, cgroup)
- lastNetStat = DoNetworkStats(stderr, cgroup, lastNetStat)