mirror of
https://github.com/acepanel/panel.git
synced 2026-02-04 22:07:16 +08:00
* refactor: 重构部分完成 * fix: 添加.gitkeep * fix: build * fix: lint * fix: lint * chore(deps): Update module github.com/go-playground/validator/v10 to v10.22.1 (#162) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): Update module gorm.io/gorm to v1.25.12 (#161) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): Update module golang.org/x/net to v0.29.0 (#159) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * workflow: 更新工作流 * workflow: test new download * feat: merge frontend project * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: fix frontend build * workflow: update to ubuntu-24.04 * workflow: rename build-* * workflow: 修改fetch-depth * chore(deps): Update dependency eslint to v9 (#164) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(frontend): update dependences * chore(frontend): fix lint * chore(frontend): fix lint * workflow: add govulncheck * workflow: disable nilaway * feat: 使用新的压缩解压库 * fix: 测试 * fix: 测试 * fix: 测试 * feat: 添加ntp包 * chore(deps): Lock file maintenance (#168) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): Update module github.com/go-resty/resty/v2 to v2.15.0 (#167) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): Update dependency @iconify/json to v2.2.249 (#169) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * feat: 添加限流器 * feat: 调整登录限流 * feat: 证书 * fix: lint * feat: 证书dns * feat: 证书acme账号 * fix: 修改UserID导致的一系列问题 * feat: 低配版任务队列 * feat: 队列完成 * fix: lint * fix: lint * fix: swagger和前端路由 * fix: 去掉ntp测试 * feat: 完成插件接口 * feat: 完成cron * feat: 完成safe * chore(deps): Update dependency vue to v3.5.6 (#170) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): Update dependency @vueuse/core to v11.1.0 (#171) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): Update dependency vite to v5.4.6 (#173) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore(deps): Update unocss monorepo to v0.62.4 (#172) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> * chore: update renovate config * feat: 新的firewall客户端 * fix: lint * feat: firewall完成 * feat: ssh完成 * feat: 容器完成1/2 * feat: 容器完成 * feat: 文件完成 * feat: systemctl及设置 * fix: windows编译 * fix: session not work * fix: migrate not work * feat: 前端路由 * feat: 初步支持cli --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
157 lines
4.5 KiB
Go
157 lines
4.5 KiB
Go
package service
|
|
|
|
import (
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/golang-module/carbon/v2"
|
|
|
|
"github.com/TheTNB/panel/internal/biz"
|
|
"github.com/TheTNB/panel/internal/data"
|
|
"github.com/TheTNB/panel/internal/http/request"
|
|
)
|
|
|
|
type MonitorService struct {
|
|
settingRepo biz.SettingRepo
|
|
monitorRepo biz.MonitorRepo
|
|
}
|
|
|
|
func NewMonitorService() *MonitorService {
|
|
return &MonitorService{
|
|
settingRepo: data.NewSettingRepo(),
|
|
monitorRepo: data.NewMonitorRepo(),
|
|
}
|
|
}
|
|
|
|
func (s *MonitorService) GetSetting(w http.ResponseWriter, r *http.Request) {
|
|
setting, err := s.monitorRepo.GetSetting()
|
|
if err != nil {
|
|
Error(w, http.StatusInternalServerError, err.Error())
|
|
return
|
|
}
|
|
|
|
Success(w, setting)
|
|
}
|
|
|
|
func (s *MonitorService) UpdateSetting(w http.ResponseWriter, r *http.Request) {
|
|
req, err := Bind[request.MonitorSetting](r)
|
|
if err != nil {
|
|
Error(w, http.StatusUnprocessableEntity, err.Error())
|
|
return
|
|
}
|
|
|
|
if err = s.monitorRepo.UpdateSetting(req); err != nil {
|
|
Error(w, http.StatusInternalServerError, err.Error())
|
|
return
|
|
}
|
|
|
|
Success(w, nil)
|
|
}
|
|
|
|
func (s *MonitorService) Clear(w http.ResponseWriter, r *http.Request) {
|
|
if err := s.monitorRepo.Clear(); err != nil {
|
|
Error(w, http.StatusInternalServerError, err.Error())
|
|
return
|
|
}
|
|
|
|
Success(w, nil)
|
|
}
|
|
|
|
func (s *MonitorService) List(w http.ResponseWriter, r *http.Request) {
|
|
req, err := Bind[request.MonitorList](r)
|
|
if err != nil {
|
|
Error(w, http.StatusUnprocessableEntity, err.Error())
|
|
return
|
|
}
|
|
|
|
monitors, err := s.monitorRepo.List(carbon.CreateFromTimestampMilli(req.Start), carbon.CreateFromTimestampMilli(req.End))
|
|
if err != nil {
|
|
Error(w, http.StatusInternalServerError, err.Error())
|
|
return
|
|
}
|
|
|
|
type load struct {
|
|
Load1 []float64 `json:"load1"`
|
|
Load5 []float64 `json:"load5"`
|
|
Load15 []float64 `json:"load15"`
|
|
}
|
|
type cpu struct {
|
|
Percent []string `json:"percent"`
|
|
}
|
|
type mem struct {
|
|
Total string `json:"total"`
|
|
Available []string `json:"available"`
|
|
Used []string `json:"used"`
|
|
}
|
|
type swap struct {
|
|
Total string `json:"total"`
|
|
Used []string `json:"used"`
|
|
Free []string `json:"free"`
|
|
}
|
|
type network struct {
|
|
Sent []string `json:"sent"`
|
|
Recv []string `json:"recv"`
|
|
Tx []string `json:"tx"`
|
|
Rx []string `json:"rx"`
|
|
}
|
|
type monitorData struct {
|
|
Times []string `json:"times"`
|
|
Load load `json:"load"`
|
|
Cpu cpu `json:"cpu"`
|
|
Mem mem `json:"mem"`
|
|
Swap swap `json:"swap"`
|
|
Net network `json:"net"`
|
|
}
|
|
|
|
var data monitorData
|
|
var bytesSent uint64
|
|
var bytesRecv uint64
|
|
var bytesSent2 uint64
|
|
var bytesRecv2 uint64
|
|
for _, net := range monitors[0].Info.Net {
|
|
if net.Name == "lo" {
|
|
continue
|
|
}
|
|
bytesSent += net.BytesSent
|
|
bytesRecv += net.BytesRecv
|
|
}
|
|
for i, monitor := range monitors {
|
|
// 跳过第一条数据,因为第一条数据的流量为 0
|
|
if i == 0 {
|
|
// MB
|
|
data.Mem.Total = fmt.Sprintf("%.2f", float64(monitor.Info.Mem.Total)/1024/1024)
|
|
data.Swap.Total = fmt.Sprintf("%.2f", float64(monitor.Info.Swap.Total)/1024/1024)
|
|
continue
|
|
}
|
|
for _, net := range monitor.Info.Net {
|
|
if net.Name == "lo" {
|
|
continue
|
|
}
|
|
bytesSent2 += net.BytesSent
|
|
bytesRecv2 += net.BytesRecv
|
|
}
|
|
data.Times = append(data.Times, monitor.CreatedAt.ToDateTimeString())
|
|
data.Load.Load1 = append(data.Load.Load1, monitor.Info.Load.Load1)
|
|
data.Load.Load5 = append(data.Load.Load5, monitor.Info.Load.Load5)
|
|
data.Load.Load15 = append(data.Load.Load15, monitor.Info.Load.Load15)
|
|
data.Cpu.Percent = append(data.Cpu.Percent, fmt.Sprintf("%.2f", monitor.Info.Percent[0]))
|
|
data.Mem.Available = append(data.Mem.Available, fmt.Sprintf("%.2f", float64(monitor.Info.Mem.Available)/1024/1024))
|
|
data.Mem.Used = append(data.Mem.Used, fmt.Sprintf("%.2f", float64(monitor.Info.Mem.Used)/1024/1024))
|
|
data.Swap.Used = append(data.Swap.Used, fmt.Sprintf("%.2f", float64(monitor.Info.Swap.Used)/1024/1024))
|
|
data.Swap.Free = append(data.Swap.Free, fmt.Sprintf("%.2f", float64(monitor.Info.Swap.Free)/1024/1024))
|
|
data.Net.Sent = append(data.Net.Sent, fmt.Sprintf("%.2f", float64(bytesSent2/1024/1024)))
|
|
data.Net.Recv = append(data.Net.Recv, fmt.Sprintf("%.2f", float64(bytesRecv2/1024/1024)))
|
|
|
|
// 监控频率为 1 分钟,所以这里除以 60 即可得到每秒的流量
|
|
data.Net.Tx = append(data.Net.Tx, fmt.Sprintf("%.2f", float64(bytesSent2-bytesSent)/60/1024/1024))
|
|
data.Net.Rx = append(data.Net.Rx, fmt.Sprintf("%.2f", float64(bytesRecv2-bytesRecv)/60/1024/1024))
|
|
|
|
bytesSent = bytesSent2
|
|
bytesRecv = bytesRecv2
|
|
bytesSent2 = 0
|
|
bytesRecv2 = 0
|
|
}
|
|
|
|
Success(w, data)
|
|
}
|