func NetIOCounters(pernic bool) ([]NetIOCountersStat, error) { out, err := exec.Command("/usr/bin/netstat", "-ibdn").Output() if err != nil { return nil, err } lines := strings.Split(string(out), "\n") ret := make([]NetIOCountersStat, 0, len(lines)-1) exists := make([]string, 0, len(ret)) for _, line := range lines { values := strings.Fields(line) if len(values) < 1 || values[0] == "Name" { continue } if common.StringsHas(exists, values[0]) { // skip if already get continue } exists = append(exists, values[0]) base := 1 // sometimes Address is ommitted if len(values) < 13 { base = 0 } parsed := make([]uint64, 0, 8) vv := []string{ values[base+3], // PacketsRecv values[base+4], // Errin values[base+5], // Dropin values[base+6], // BytesRecvn values[base+7], // PacketSent values[base+8], // Errout values[base+9], // BytesSent values[base+11], // Dropout } for _, target := range vv { if target == "-" { parsed = append(parsed, 0) continue } t, err := strconv.ParseUint(target, 10, 64) if err != nil { return nil, err } parsed = append(parsed, t) } n := NetIOCountersStat{ Name: values[0], PacketsRecv: parsed[0], Errin: parsed[1], Dropin: parsed[2], BytesRecv: parsed[3], PacketsSent: parsed[4], Errout: parsed[5], BytesSent: parsed[6], Dropout: parsed[7], } ret = append(ret, n) } if pernic == false { return getNetIOCountersAll(ret) } return ret, nil }
func GetVirtualization() (string, string, error) { var system string var role string if common.PathExists("/proc/xen") { system = "xen" role = "guest" // assume guest if common.PathExists("/proc/xen/capabilities") { contents, err := common.ReadLines("/proc/xen/capabilities") if err == nil { if common.StringsHas(contents, "control_d") { role = "host" } } } } if common.PathExists("/proc/modules") { contents, err := common.ReadLines("/proc/modules") if err == nil { if common.StringsContains(contents, "kvm") { system = "kvm" role = "host" } else if common.StringsContains(contents, "vboxdrv") { system = "vbox" role = "host" } else if common.StringsContains(contents, "vboxguest") { system = "vbox" role = "guest" } } } if common.PathExists("/proc/cpuinfo") { contents, err := common.ReadLines("/proc/cpuinfo") if err == nil { if common.StringsHas(contents, "QEMU Virtual CPU") || common.StringsHas(contents, "Common KVM processor") || common.StringsHas(contents, "Common 32-bit KVM processor") { system = "kvm" role = "guest" } } } if common.PathExists("/proc/bc/0") { system = "openvz" role = "host" } else if common.PathExists("/proc/vz") { system = "openvz" role = "guest" } // not use dmidecode because it requires root if common.PathExists("/proc/self/status") { contents, err := common.ReadLines("/proc/self/status") if err == nil { if common.StringsHas(contents, "s_context:") || common.StringsHas(contents, "VxID:") { system = "linux-vserver" } // TODO: guest or host } } if common.PathExists("/proc/self/cgroup") { contents, err := common.ReadLines("/proc/self/cgroup") if err == nil { if common.StringsHas(contents, "lxc") || common.StringsHas(contents, "docker") { system = "lxc" role = "guest" } else if common.PathExists("/usr/bin/lxc-version") { // TODO: which system = "lxc" role = "host" } } } return system, role, nil }