nezha/service/monitor/monitor.go

129 lines
2.9 KiB
Go
Raw Normal View History

2019-12-07 05:14:40 -05:00
package monitor
import (
2019-12-09 03:02:49 -05:00
"encoding/json"
2019-12-07 05:14:40 -05:00
"fmt"
2019-12-09 03:02:49 -05:00
"io/ioutil"
"net/http"
"strings"
2019-12-07 05:14:40 -05:00
"time"
"github.com/shirou/gopsutil/cpu"
"github.com/shirou/gopsutil/disk"
"github.com/shirou/gopsutil/host"
"github.com/shirou/gopsutil/mem"
"github.com/shirou/gopsutil/net"
"github.com/p14yground/nezha/model"
2019-12-09 10:45:23 -05:00
"github.com/p14yground/nezha/service/dao"
2019-12-07 05:14:40 -05:00
)
2019-12-09 03:02:49 -05:00
type ipDotSbGeoIP struct {
CountryCode string
IP string
}
2019-12-09 10:45:23 -05:00
var netInSpeed, netOutSpeed, netInTransfer, netOutTransfer, lastUpdate uint64
2019-12-07 05:14:40 -05:00
// GetHost ..
func GetHost() *model.Host {
hi, _ := host.Info()
var cpus []string
ci, _ := cpu.Info()
for i := 0; i < len(ci); i++ {
cpus = append(cpus, fmt.Sprintf("%v-%vC%vT", ci[i].ModelName, ci[i].Cores, ci[i].Stepping))
}
2019-12-09 03:02:49 -05:00
ip := ipDotSbGeoIP{
IP: "127.0.0.1",
CountryCode: "cn",
}
resp, err := http.Get("https://api.ip.sb/geoip")
if err == nil {
defer resp.Body.Close()
body, _ := ioutil.ReadAll(resp.Body)
json.Unmarshal(body, &ip)
}
2019-12-07 05:14:40 -05:00
return &model.Host{
Platform: hi.OS,
PlatformVersion: hi.PlatformVersion,
CPU: cpus,
Arch: hi.KernelArch,
Virtualization: hi.VirtualizationSystem,
2019-12-09 10:45:23 -05:00
BootTime: hi.BootTime,
2019-12-09 03:02:49 -05:00
IP: ip.IP,
CountryCode: strings.ToLower(ip.CountryCode),
2019-12-09 10:45:23 -05:00
Version: dao.Version,
2019-12-07 05:14:40 -05:00
}
}
// GetState ..
2019-12-09 10:45:23 -05:00
func GetState(delay int64) *model.State {
hi, _ := host.Info()
2019-12-07 05:14:40 -05:00
// Memory
mv, _ := mem.VirtualMemory()
ms, _ := mem.SwapMemory()
2019-12-09 10:45:23 -05:00
// CPU
var cpuPercent float64
cp, err := cpu.Percent(time.Second*time.Duration(delay), false)
if err == nil {
cpuPercent = cp[0]
}
2019-12-07 05:14:40 -05:00
// Disk
var diskTotal, diskUsed uint64
dparts, _ := disk.Partitions(true)
2019-12-09 10:45:23 -05:00
var lastDevice string
2019-12-07 05:14:40 -05:00
for _, part := range dparts {
u, _ := disk.Usage(part.Mountpoint)
2019-12-09 10:45:23 -05:00
if lastDevice != part.Device {
diskTotal += u.Total
lastDevice = part.Device
}
2019-12-07 05:14:40 -05:00
diskUsed += u.Used
}
2019-12-09 10:45:23 -05:00
return &model.State{
CPU: cpuPercent,
MemTotal: mv.Total,
MemUsed: mv.Used,
SwapTotal: ms.Total,
SwapUsed: ms.Used,
DiskTotal: diskTotal,
DiskUsed: diskUsed,
NetInTransfer: netInTransfer,
NetOutTransfer: netOutTransfer,
NetInSpeed: netInSpeed,
NetOutSpeed: netOutSpeed,
Uptime: hi.Uptime,
2019-12-07 05:14:40 -05:00
}
2019-12-09 10:45:23 -05:00
}
// TrackNetworkSpeed ..
func TrackNetworkSpeed() {
var innerNetInTransfer, innerNetOutTransfer uint64
nc, err := net.IOCounters(true)
2019-12-07 05:14:40 -05:00
if err == nil {
2019-12-09 10:45:23 -05:00
for i := 0; i < len(nc); i++ {
if strings.HasPrefix(nc[i].Name, "e") {
innerNetInTransfer += nc[i].BytesRecv
innerNetOutTransfer += nc[i].BytesSent
}
}
if netInTransfer == 0 {
netInTransfer = innerNetInTransfer
}
if netOutTransfer == 0 {
netOutTransfer = innerNetOutTransfer
}
diff := uint64(time.Now().Unix())
if lastUpdate == 0 {
lastUpdate = diff
return
}
diff -= lastUpdate
if diff > 0 {
netInSpeed = (innerNetInTransfer - netInTransfer) / diff
netOutSpeed = (innerNetOutTransfer - netOutTransfer) / diff
}
2019-12-07 05:14:40 -05:00
}
}