From e0e2cb5f51314860178e6a9808c60abefa003a22 Mon Sep 17 00:00:00 2001 From: thun888 <2238342947@qq.com> Date: Sun, 24 Mar 2024 11:02:23 +0800 Subject: [PATCH] [FIX]History Record (#22) * fix * [Opt][Incomplete]Optimize history processing * [FIX][Build APP]Rclone --- modules/database/base.go | 33 ++++++++++++++++++++------------- 1 file changed, 20 insertions(+), 13 deletions(-) diff --git a/modules/database/base.go b/modules/database/base.go index ea6db1a..612dbde 100644 --- a/modules/database/base.go +++ b/modules/database/base.go @@ -122,25 +122,32 @@ func Savetodb(databasepath string, dev []config.Dev, tokens map[int]string, maxs downSpeed := float64(info.DownSpeed) / 1024 / 1024 upTotal := float64(info.Upload) / 1024 / 1024 downTotal := float64(info.Download) / 1024 / 1024 + db.Create(&DevicesHistory{ + Mac: mac, + UpSpeed: upSpeed, + DownSpeed: downSpeed, + UpTotal: upTotal, + DownTotal: downTotal, + }) db.Model(&DevicesHistory{}).Where("mac = ?", routerNum).Count(&count) if count >= int64(maxsaved) { logrus.Debug("删除历史数据") db.Exec("DELETE FROM histories WHERE mac = ? AND created_at = (SELECT MIN(created_at) FROM histories WHERE mac = ? );", mac, mac) } - db.Create(&History{ - Ip: ip, - RouterNum: routerNum, - Cpu: cpu, - Cpu_tp: cpu_tp, - Mem: mem, - UpSpeed: upSpeed, - DownSpeed: downSpeed, - UpTotal: upTotal, - DownTotal: downTotal, - DeviceNum: deviceNum, - }) } + db.Create(&History{ + Ip: ip, + RouterNum: routerNum, + Cpu: cpu, + Cpu_tp: cpu_tp, + Mem: mem, + UpSpeed: upSpeed, + DownSpeed: downSpeed, + UpTotal: upTotal, + DownTotal: downTotal, + DeviceNum: deviceNum, + }) } } @@ -177,7 +184,7 @@ func getRouterStats(routernum int, tokens map[int]string, ip string) (float64, i cpu_tp := int(result["temperature"].(float64)) memusage := result["mem"].(map[string]interface{})["usage"].(float64) * 100 devicenum_now := int(result["count"].(map[string]interface{})["online"].(float64)) - devs := result["devs"].([]interface{}) + devs := result["dev"].([]interface{}) return cpuload, cpu_tp, memusage, upspeed, downspeed, uploadtotal, downloadtotal, devicenum_now, devs }