mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2025-01-19 00:09:16 +08:00
perf: 优化首页加载速度 (#6461)
This commit is contained in:
parent
fc70345fcd
commit
d2ca265cc2
@ -2,6 +2,7 @@ package v1
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
|
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
||||||
|
|
||||||
"github.com/1Panel-dev/1Panel/backend/app/api/v1/helper"
|
"github.com/1Panel-dev/1Panel/backend/app/api/v1/helper"
|
||||||
"github.com/1Panel-dev/1Panel/backend/constant"
|
"github.com/1Panel-dev/1Panel/backend/constant"
|
||||||
@ -55,25 +56,17 @@ func (b *BaseApi) LoadDashboardBaseInfo(c *gin.Context) {
|
|||||||
// @Tags Dashboard
|
// @Tags Dashboard
|
||||||
// @Summary Load dashboard current info
|
// @Summary Load dashboard current info
|
||||||
// @Description 获取首页实时数据
|
// @Description 获取首页实时数据
|
||||||
// @Accept json
|
// @Accept json、
|
||||||
// @Param ioOption path string true "request"
|
// @Param request body dto.DashboardReq true "request"
|
||||||
// @Param netOption path string true "request"
|
|
||||||
// @Success 200 {object} dto.DashboardCurrent
|
// @Success 200 {object} dto.DashboardCurrent
|
||||||
// @Security ApiKeyAuth
|
// @Security ApiKeyAuth
|
||||||
// @Router /dashboard/current/:ioOption/:netOption [get]
|
// @Router /dashboard/current [post]
|
||||||
func (b *BaseApi) LoadDashboardCurrentInfo(c *gin.Context) {
|
func (b *BaseApi) LoadDashboardCurrentInfo(c *gin.Context) {
|
||||||
ioOption, ok := c.Params.Get("ioOption")
|
var req dto.DashboardReq
|
||||||
if !ok {
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
||||||
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, errors.New("error ioOption in path"))
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
netOption, ok := c.Params.Get("netOption")
|
data := dashboardService.LoadCurrentInfo(req)
|
||||||
if !ok {
|
|
||||||
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, errors.New("error netOption in path"))
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
data := dashboardService.LoadCurrentInfo(ioOption, netOption)
|
|
||||||
helper.SuccessWithData(c, data)
|
helper.SuccessWithData(c, data)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,6 +35,12 @@ type OsInfo struct {
|
|||||||
DiskSize int64 `json:"diskSize"`
|
DiskSize int64 `json:"diskSize"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type DashboardReq struct {
|
||||||
|
Scope string `json:"scope"`
|
||||||
|
IoOption string `json:"ioOption"`
|
||||||
|
NetOption string `json:"netOption"`
|
||||||
|
}
|
||||||
|
|
||||||
type DashboardCurrent struct {
|
type DashboardCurrent struct {
|
||||||
Uptime uint64 `json:"uptime"`
|
Uptime uint64 `json:"uptime"`
|
||||||
TimeSinceUptime string `json:"timeSinceUptime"`
|
TimeSinceUptime string `json:"timeSinceUptime"`
|
||||||
|
@ -3,6 +3,10 @@ package service
|
|||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"github.com/1Panel-dev/1Panel/backend/constant"
|
||||||
|
"github.com/shirou/gopsutil/v3/load"
|
||||||
|
"github.com/shirou/gopsutil/v3/mem"
|
||||||
|
"github.com/shirou/gopsutil/v3/net"
|
||||||
network "net"
|
network "net"
|
||||||
"os"
|
"os"
|
||||||
"sort"
|
"sort"
|
||||||
@ -11,7 +15,6 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
||||||
"github.com/1Panel-dev/1Panel/backend/constant"
|
|
||||||
"github.com/1Panel-dev/1Panel/backend/global"
|
"github.com/1Panel-dev/1Panel/backend/global"
|
||||||
"github.com/1Panel-dev/1Panel/backend/utils/cmd"
|
"github.com/1Panel-dev/1Panel/backend/utils/cmd"
|
||||||
"github.com/1Panel-dev/1Panel/backend/utils/copier"
|
"github.com/1Panel-dev/1Panel/backend/utils/copier"
|
||||||
@ -19,9 +22,6 @@ import (
|
|||||||
"github.com/shirou/gopsutil/v3/cpu"
|
"github.com/shirou/gopsutil/v3/cpu"
|
||||||
"github.com/shirou/gopsutil/v3/disk"
|
"github.com/shirou/gopsutil/v3/disk"
|
||||||
"github.com/shirou/gopsutil/v3/host"
|
"github.com/shirou/gopsutil/v3/host"
|
||||||
"github.com/shirou/gopsutil/v3/load"
|
|
||||||
"github.com/shirou/gopsutil/v3/mem"
|
|
||||||
"github.com/shirou/gopsutil/v3/net"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type DashboardService struct{}
|
type DashboardService struct{}
|
||||||
@ -29,7 +29,7 @@ type DashboardService struct{}
|
|||||||
type IDashboardService interface {
|
type IDashboardService interface {
|
||||||
LoadOsInfo() (*dto.OsInfo, error)
|
LoadOsInfo() (*dto.OsInfo, error)
|
||||||
LoadBaseInfo(ioOption string, netOption string) (*dto.DashboardBase, error)
|
LoadBaseInfo(ioOption string, netOption string) (*dto.DashboardBase, error)
|
||||||
LoadCurrentInfo(ioOption string, netOption string) *dto.DashboardCurrent
|
LoadCurrentInfo(req dto.DashboardReq) *dto.DashboardCurrent
|
||||||
|
|
||||||
Restart(operation string) error
|
Restart(operation string) error
|
||||||
}
|
}
|
||||||
@ -139,79 +139,88 @@ func (u *DashboardService) LoadBaseInfo(ioOption string, netOption string) (*dto
|
|||||||
baseInfo.CPUCores, _ = cpu.Counts(false)
|
baseInfo.CPUCores, _ = cpu.Counts(false)
|
||||||
baseInfo.CPULogicalCores, _ = cpu.Counts(true)
|
baseInfo.CPULogicalCores, _ = cpu.Counts(true)
|
||||||
|
|
||||||
baseInfo.CurrentInfo = *u.LoadCurrentInfo(ioOption, netOption)
|
baseInfo.CurrentInfo = *u.LoadCurrentInfo(dto.DashboardReq{
|
||||||
|
Scope: "ioNet",
|
||||||
|
IoOption: ioOption,
|
||||||
|
NetOption: netOption,
|
||||||
|
})
|
||||||
return &baseInfo, nil
|
return &baseInfo, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (u *DashboardService) LoadCurrentInfo(ioOption string, netOption string) *dto.DashboardCurrent {
|
func (u *DashboardService) LoadCurrentInfo(req dto.DashboardReq) *dto.DashboardCurrent {
|
||||||
var currentInfo dto.DashboardCurrent
|
var currentInfo dto.DashboardCurrent
|
||||||
|
if req.Scope == "gpu" {
|
||||||
|
currentInfo.GPUData = loadGPUInfo()
|
||||||
|
currentInfo.XPUData = loadXpuInfo()
|
||||||
|
}
|
||||||
|
|
||||||
hostInfo, _ := host.Info()
|
hostInfo, _ := host.Info()
|
||||||
currentInfo.Uptime = hostInfo.Uptime
|
currentInfo.Uptime = hostInfo.Uptime
|
||||||
currentInfo.TimeSinceUptime = time.Now().Add(-time.Duration(hostInfo.Uptime) * time.Second).Format(constant.DateTimeLayout)
|
if req.Scope == "basic" {
|
||||||
currentInfo.Procs = hostInfo.Procs
|
currentInfo.TimeSinceUptime = time.Now().Add(-time.Duration(hostInfo.Uptime) * time.Second).Format(constant.DateTimeLayout)
|
||||||
|
currentInfo.Procs = hostInfo.Procs
|
||||||
currentInfo.CPUTotal, _ = cpu.Counts(true)
|
currentInfo.CPUTotal, _ = cpu.Counts(true)
|
||||||
totalPercent, _ := cpu.Percent(100*time.Millisecond, false)
|
totalPercent, _ := cpu.Percent(100*time.Millisecond, false)
|
||||||
if len(totalPercent) == 1 {
|
if len(totalPercent) == 1 {
|
||||||
currentInfo.CPUUsedPercent = totalPercent[0]
|
currentInfo.CPUUsedPercent = totalPercent[0]
|
||||||
currentInfo.CPUUsed = currentInfo.CPUUsedPercent * 0.01 * float64(currentInfo.CPUTotal)
|
currentInfo.CPUUsed = currentInfo.CPUUsedPercent * 0.01 * float64(currentInfo.CPUTotal)
|
||||||
}
|
|
||||||
currentInfo.CPUPercent, _ = cpu.Percent(100*time.Millisecond, true)
|
|
||||||
|
|
||||||
loadInfo, _ := load.Avg()
|
|
||||||
currentInfo.Load1 = loadInfo.Load1
|
|
||||||
currentInfo.Load5 = loadInfo.Load5
|
|
||||||
currentInfo.Load15 = loadInfo.Load15
|
|
||||||
currentInfo.LoadUsagePercent = loadInfo.Load1 / (float64(currentInfo.CPUTotal*2) * 0.75) * 100
|
|
||||||
|
|
||||||
memoryInfo, _ := mem.VirtualMemory()
|
|
||||||
currentInfo.MemoryTotal = memoryInfo.Total
|
|
||||||
currentInfo.MemoryAvailable = memoryInfo.Available
|
|
||||||
currentInfo.MemoryUsed = memoryInfo.Used
|
|
||||||
currentInfo.MemoryUsedPercent = memoryInfo.UsedPercent
|
|
||||||
|
|
||||||
swapInfo, _ := mem.SwapMemory()
|
|
||||||
currentInfo.SwapMemoryTotal = swapInfo.Total
|
|
||||||
currentInfo.SwapMemoryAvailable = swapInfo.Free
|
|
||||||
currentInfo.SwapMemoryUsed = swapInfo.Used
|
|
||||||
currentInfo.SwapMemoryUsedPercent = swapInfo.UsedPercent
|
|
||||||
|
|
||||||
currentInfo.DiskData = loadDiskInfo()
|
|
||||||
currentInfo.GPUData = loadGPUInfo()
|
|
||||||
currentInfo.XPUData = loadXpuInfo()
|
|
||||||
|
|
||||||
if ioOption == "all" {
|
|
||||||
diskInfo, _ := disk.IOCounters()
|
|
||||||
for _, state := range diskInfo {
|
|
||||||
currentInfo.IOReadBytes += state.ReadBytes
|
|
||||||
currentInfo.IOWriteBytes += state.WriteBytes
|
|
||||||
currentInfo.IOCount += (state.ReadCount + state.WriteCount)
|
|
||||||
currentInfo.IOReadTime += state.ReadTime
|
|
||||||
currentInfo.IOWriteTime += state.WriteTime
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
diskInfo, _ := disk.IOCounters(ioOption)
|
|
||||||
for _, state := range diskInfo {
|
|
||||||
currentInfo.IOReadBytes += state.ReadBytes
|
|
||||||
currentInfo.IOWriteBytes += state.WriteBytes
|
|
||||||
currentInfo.IOCount += (state.ReadCount + state.WriteCount)
|
|
||||||
currentInfo.IOReadTime += state.ReadTime
|
|
||||||
currentInfo.IOWriteTime += state.WriteTime
|
|
||||||
}
|
}
|
||||||
|
currentInfo.CPUPercent, _ = cpu.Percent(100*time.Millisecond, true)
|
||||||
|
|
||||||
|
loadInfo, _ := load.Avg()
|
||||||
|
currentInfo.Load1 = loadInfo.Load1
|
||||||
|
currentInfo.Load5 = loadInfo.Load5
|
||||||
|
currentInfo.Load15 = loadInfo.Load15
|
||||||
|
currentInfo.LoadUsagePercent = loadInfo.Load1 / (float64(currentInfo.CPUTotal*2) * 0.75) * 100
|
||||||
|
|
||||||
|
memoryInfo, _ := mem.VirtualMemory()
|
||||||
|
currentInfo.MemoryTotal = memoryInfo.Total
|
||||||
|
currentInfo.MemoryAvailable = memoryInfo.Available
|
||||||
|
currentInfo.MemoryUsed = memoryInfo.Used
|
||||||
|
currentInfo.MemoryUsedPercent = memoryInfo.UsedPercent
|
||||||
|
|
||||||
|
swapInfo, _ := mem.SwapMemory()
|
||||||
|
currentInfo.SwapMemoryTotal = swapInfo.Total
|
||||||
|
currentInfo.SwapMemoryAvailable = swapInfo.Free
|
||||||
|
currentInfo.SwapMemoryUsed = swapInfo.Used
|
||||||
|
currentInfo.SwapMemoryUsedPercent = swapInfo.UsedPercent
|
||||||
|
currentInfo.DiskData = loadDiskInfo()
|
||||||
}
|
}
|
||||||
|
|
||||||
if netOption == "all" {
|
if req.Scope == "ioNet" {
|
||||||
netInfo, _ := net.IOCounters(false)
|
if req.IoOption == "all" {
|
||||||
if len(netInfo) != 0 {
|
diskInfo, _ := disk.IOCounters()
|
||||||
currentInfo.NetBytesSent = netInfo[0].BytesSent
|
for _, state := range diskInfo {
|
||||||
currentInfo.NetBytesRecv = netInfo[0].BytesRecv
|
currentInfo.IOReadBytes += state.ReadBytes
|
||||||
|
currentInfo.IOWriteBytes += state.WriteBytes
|
||||||
|
currentInfo.IOCount += (state.ReadCount + state.WriteCount)
|
||||||
|
currentInfo.IOReadTime += state.ReadTime
|
||||||
|
currentInfo.IOWriteTime += state.WriteTime
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
diskInfo, _ := disk.IOCounters(req.IoOption)
|
||||||
|
for _, state := range diskInfo {
|
||||||
|
currentInfo.IOReadBytes += state.ReadBytes
|
||||||
|
currentInfo.IOWriteBytes += state.WriteBytes
|
||||||
|
currentInfo.IOCount += (state.ReadCount + state.WriteCount)
|
||||||
|
currentInfo.IOReadTime += state.ReadTime
|
||||||
|
currentInfo.IOWriteTime += state.WriteTime
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
netInfo, _ := net.IOCounters(true)
|
if req.NetOption == "all" {
|
||||||
for _, state := range netInfo {
|
netInfo, _ := net.IOCounters(false)
|
||||||
if state.Name == netOption {
|
if len(netInfo) != 0 {
|
||||||
currentInfo.NetBytesSent = state.BytesSent
|
currentInfo.NetBytesSent = netInfo[0].BytesSent
|
||||||
currentInfo.NetBytesRecv = state.BytesRecv
|
currentInfo.NetBytesRecv = netInfo[0].BytesRecv
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
netInfo, _ := net.IOCounters(true)
|
||||||
|
for _, state := range netInfo {
|
||||||
|
if state.Name == req.NetOption {
|
||||||
|
currentInfo.NetBytesSent = state.BytesSent
|
||||||
|
currentInfo.NetBytesRecv = state.BytesRecv
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,7 @@ func (s *DashboardRouter) InitRouter(Router *gin.RouterGroup) {
|
|||||||
{
|
{
|
||||||
cmdRouter.GET("/base/os", baseApi.LoadDashboardOsInfo)
|
cmdRouter.GET("/base/os", baseApi.LoadDashboardOsInfo)
|
||||||
cmdRouter.GET("/base/:ioOption/:netOption", baseApi.LoadDashboardBaseInfo)
|
cmdRouter.GET("/base/:ioOption/:netOption", baseApi.LoadDashboardBaseInfo)
|
||||||
cmdRouter.GET("/current/:ioOption/:netOption", baseApi.LoadDashboardCurrentInfo)
|
cmdRouter.POST("/current", baseApi.LoadDashboardCurrentInfo)
|
||||||
cmdRouter.POST("/system/restart/:operation", baseApi.SystemRestart)
|
cmdRouter.POST("/system/restart/:operation", baseApi.SystemRestart)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -105,4 +105,10 @@ export namespace Dashboard {
|
|||||||
power: string;
|
power: string;
|
||||||
memoryUtil: string;
|
memoryUtil: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface DashboardReq {
|
||||||
|
scope: string;
|
||||||
|
ioOption: string;
|
||||||
|
netOption: string;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,8 +9,8 @@ export const loadBaseInfo = (ioOption: string, netOption: string) => {
|
|||||||
return http.get<Dashboard.BaseInfo>(`/dashboard/base/${ioOption}/${netOption}`);
|
return http.get<Dashboard.BaseInfo>(`/dashboard/base/${ioOption}/${netOption}`);
|
||||||
};
|
};
|
||||||
|
|
||||||
export const loadCurrentInfo = (ioOption: string, netOption: string) => {
|
export const loadCurrentInfo = (req: Dashboard.DashboardReq) => {
|
||||||
return http.get<Dashboard.CurrentInfo>(`/dashboard/current/${ioOption}/${netOption}`);
|
return http.post<Dashboard.CurrentInfo>(`/dashboard/current`, req);
|
||||||
};
|
};
|
||||||
|
|
||||||
export const systemRestart = (operation: string) => {
|
export const systemRestart = (operation: string) => {
|
||||||
|
@ -309,6 +309,7 @@ const isProductPro = ref();
|
|||||||
const searchInfo = reactive({
|
const searchInfo = reactive({
|
||||||
ioOption: 'all',
|
ioOption: 'all',
|
||||||
netOption: 'all',
|
netOption: 'all',
|
||||||
|
scope: 'all',
|
||||||
});
|
});
|
||||||
|
|
||||||
const baseInfo = ref<Dashboard.BaseInfo>({
|
const baseInfo = ref<Dashboard.BaseInfo>({
|
||||||
@ -416,79 +417,153 @@ const onLoadBaseInfo = async (isInit: boolean, range: string) => {
|
|||||||
}
|
}
|
||||||
const res = await loadBaseInfo(searchInfo.ioOption, searchInfo.netOption);
|
const res = await loadBaseInfo(searchInfo.ioOption, searchInfo.netOption);
|
||||||
baseInfo.value = res.data;
|
baseInfo.value = res.data;
|
||||||
currentInfo.value = baseInfo.value.currentInfo;
|
|
||||||
await onLoadCurrentInfo();
|
const resData = res.data.currentInfo;
|
||||||
|
currentInfo.value.ioReadBytes = resData.ioReadBytes;
|
||||||
|
currentInfo.value.ioWriteBytes = resData.ioWriteBytes;
|
||||||
|
currentInfo.value.ioCount = resData.ioCount;
|
||||||
|
currentInfo.value.ioReadTime = resData.ioReadTime;
|
||||||
|
currentInfo.value.ioWriteTime = resData.ioWriteTime;
|
||||||
|
currentInfo.value.netBytesSent = resData.netBytesSent;
|
||||||
|
currentInfo.value.netBytesRecv = resData.netBytesRecv;
|
||||||
|
currentInfo.value.uptime = resData.uptime;
|
||||||
|
|
||||||
|
loadAppCurrentInfo();
|
||||||
isStatusInit.value = false;
|
isStatusInit.value = false;
|
||||||
statusRef.value.acceptParams(currentInfo.value, baseInfo.value, isStatusInit.value);
|
statusRef.value.acceptParams(currentInfo.value, baseInfo.value, isStatusInit.value);
|
||||||
appRef.value.acceptParams();
|
appRef.value.acceptParams();
|
||||||
if (isInit) {
|
if (isInit) {
|
||||||
timer = setInterval(async () => {
|
timer = setInterval(async () => {
|
||||||
if (isActive.value && !globalStore.isOnRestart) {
|
if (isActive.value && !globalStore.isOnRestart) {
|
||||||
await onLoadCurrentInfo();
|
loadAppCurrentInfo();
|
||||||
}
|
}
|
||||||
}, 3000);
|
}, 3000);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const onLoadCurrentInfo = async () => {
|
const loadAppCurrentInfo = async () => {
|
||||||
const res = await loadCurrentInfo(searchInfo.ioOption, searchInfo.netOption);
|
await Promise.all([onLoadCurrentInfo('gpu'), onLoadCurrentInfo('basic'), onLoadCurrentInfo('ioNet')]);
|
||||||
currentInfo.value.timeSinceUptime = res.data.timeSinceUptime;
|
|
||||||
|
|
||||||
let timeInterval = Number(res.data.uptime - currentInfo.value.uptime) || 3;
|
|
||||||
currentChartInfo.netBytesSent =
|
|
||||||
res.data.netBytesSent - currentInfo.value.netBytesSent > 0
|
|
||||||
? Number(((res.data.netBytesSent - currentInfo.value.netBytesSent) / 1024 / timeInterval).toFixed(2))
|
|
||||||
: 0;
|
|
||||||
netBytesSents.value.push(currentChartInfo.netBytesSent);
|
|
||||||
if (netBytesSents.value.length > 20) {
|
|
||||||
netBytesSents.value.splice(0, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
currentChartInfo.netBytesRecv =
|
|
||||||
res.data.netBytesRecv - currentInfo.value.netBytesRecv > 0
|
|
||||||
? Number(((res.data.netBytesRecv - currentInfo.value.netBytesRecv) / 1024 / timeInterval).toFixed(2))
|
|
||||||
: 0;
|
|
||||||
netBytesRecvs.value.push(currentChartInfo.netBytesRecv);
|
|
||||||
if (netBytesRecvs.value.length > 20) {
|
|
||||||
netBytesRecvs.value.splice(0, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
currentChartInfo.ioReadBytes =
|
|
||||||
res.data.ioReadBytes - currentInfo.value.ioReadBytes > 0
|
|
||||||
? Number(((res.data.ioReadBytes - currentInfo.value.ioReadBytes) / 1024 / 1024 / timeInterval).toFixed(2))
|
|
||||||
: 0;
|
|
||||||
ioReadBytes.value.push(currentChartInfo.ioReadBytes);
|
|
||||||
if (ioReadBytes.value.length > 20) {
|
|
||||||
ioReadBytes.value.splice(0, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
currentChartInfo.ioWriteBytes =
|
|
||||||
res.data.ioWriteBytes - currentInfo.value.ioWriteBytes > 0
|
|
||||||
? Number(((res.data.ioWriteBytes - currentInfo.value.ioWriteBytes) / 1024 / 1024 / timeInterval).toFixed(2))
|
|
||||||
: 0;
|
|
||||||
ioWriteBytes.value.push(currentChartInfo.ioWriteBytes);
|
|
||||||
if (ioWriteBytes.value.length > 20) {
|
|
||||||
ioWriteBytes.value.splice(0, 1);
|
|
||||||
}
|
|
||||||
currentChartInfo.ioCount = Math.round(Number((res.data.ioCount - currentInfo.value.ioCount) / timeInterval));
|
|
||||||
let ioReadTime = res.data.ioReadTime - currentInfo.value.ioReadTime;
|
|
||||||
let ioWriteTime = res.data.ioWriteTime - currentInfo.value.ioWriteTime;
|
|
||||||
let ioChoose = ioReadTime > ioWriteTime ? ioReadTime : ioWriteTime;
|
|
||||||
currentChartInfo.ioTime = Math.round(Number(ioChoose / timeInterval));
|
|
||||||
|
|
||||||
timeIODatas.value.push(dateFormatForSecond(res.data.shotTime));
|
|
||||||
if (timeIODatas.value.length > 20) {
|
|
||||||
timeIODatas.value.splice(0, 1);
|
|
||||||
}
|
|
||||||
timeNetDatas.value.push(dateFormatForSecond(res.data.shotTime));
|
|
||||||
if (timeNetDatas.value.length > 20) {
|
|
||||||
timeNetDatas.value.splice(0, 1);
|
|
||||||
}
|
|
||||||
loadData();
|
|
||||||
currentInfo.value = res.data;
|
|
||||||
statusRef.value.acceptParams(currentInfo.value, baseInfo.value, isStatusInit.value);
|
statusRef.value.acceptParams(currentInfo.value, baseInfo.value, isStatusInit.value);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const onLoadCurrentInfo = async (scope: string) => {
|
||||||
|
const req = {
|
||||||
|
scope: scope,
|
||||||
|
ioOption: searchInfo.ioOption,
|
||||||
|
netOption: searchInfo.netOption,
|
||||||
|
};
|
||||||
|
const res = await loadCurrentInfo(req);
|
||||||
|
const resData = res.data;
|
||||||
|
|
||||||
|
if (scope === 'ioNet') {
|
||||||
|
let timeInterval = Number(res.data.uptime - currentInfo.value.uptime) || 3;
|
||||||
|
currentChartInfo.netBytesSent =
|
||||||
|
res.data.netBytesSent - currentInfo.value.netBytesSent > 0
|
||||||
|
? Number(((res.data.netBytesSent - currentInfo.value.netBytesSent) / 1024 / timeInterval).toFixed(2))
|
||||||
|
: 0;
|
||||||
|
console.log('value', res.data.netBytesSent - currentInfo.value.netBytesSent);
|
||||||
|
console.log(
|
||||||
|
'number',
|
||||||
|
Number(((res.data.netBytesSent - currentInfo.value.netBytesSent) / 1024 / timeInterval).toFixed(2)),
|
||||||
|
);
|
||||||
|
netBytesSents.value.push(currentChartInfo.netBytesSent);
|
||||||
|
|
||||||
|
if (netBytesSents.value.length > 20) {
|
||||||
|
netBytesSents.value.splice(0, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
currentChartInfo.netBytesRecv =
|
||||||
|
res.data.netBytesRecv - currentInfo.value.netBytesRecv > 0
|
||||||
|
? Number(((res.data.netBytesRecv - currentInfo.value.netBytesRecv) / 1024 / timeInterval).toFixed(2))
|
||||||
|
: 0;
|
||||||
|
netBytesRecvs.value.push(currentChartInfo.netBytesRecv);
|
||||||
|
if (netBytesRecvs.value.length > 20) {
|
||||||
|
netBytesRecvs.value.splice(0, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
currentChartInfo.ioReadBytes =
|
||||||
|
res.data.ioReadBytes - currentInfo.value.ioReadBytes > 0
|
||||||
|
? Number(
|
||||||
|
((res.data.ioReadBytes - currentInfo.value.ioReadBytes) / 1024 / 1024 / timeInterval).toFixed(2),
|
||||||
|
)
|
||||||
|
: 0;
|
||||||
|
ioReadBytes.value.push(currentChartInfo.ioReadBytes);
|
||||||
|
if (ioReadBytes.value.length > 20) {
|
||||||
|
ioReadBytes.value.splice(0, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
currentChartInfo.ioWriteBytes =
|
||||||
|
res.data.ioWriteBytes - currentInfo.value.ioWriteBytes > 0
|
||||||
|
? Number(
|
||||||
|
((res.data.ioWriteBytes - currentInfo.value.ioWriteBytes) / 1024 / 1024 / timeInterval).toFixed(
|
||||||
|
2,
|
||||||
|
),
|
||||||
|
)
|
||||||
|
: 0;
|
||||||
|
ioWriteBytes.value.push(currentChartInfo.ioWriteBytes);
|
||||||
|
if (ioWriteBytes.value.length > 20) {
|
||||||
|
ioWriteBytes.value.splice(0, 1);
|
||||||
|
}
|
||||||
|
currentChartInfo.ioCount = Math.round(Number((res.data.ioCount - currentInfo.value.ioCount) / timeInterval));
|
||||||
|
let ioReadTime = res.data.ioReadTime - currentInfo.value.ioReadTime;
|
||||||
|
let ioWriteTime = res.data.ioWriteTime - currentInfo.value.ioWriteTime;
|
||||||
|
let ioChoose = ioReadTime > ioWriteTime ? ioReadTime : ioWriteTime;
|
||||||
|
currentChartInfo.ioTime = Math.round(Number(ioChoose / timeInterval));
|
||||||
|
|
||||||
|
timeIODatas.value.push(dateFormatForSecond(res.data.shotTime));
|
||||||
|
if (timeIODatas.value.length > 20) {
|
||||||
|
timeIODatas.value.splice(0, 1);
|
||||||
|
}
|
||||||
|
timeNetDatas.value.push(dateFormatForSecond(res.data.shotTime));
|
||||||
|
if (timeNetDatas.value.length > 20) {
|
||||||
|
timeNetDatas.value.splice(0, 1);
|
||||||
|
}
|
||||||
|
loadData();
|
||||||
|
|
||||||
|
currentInfo.value.ioReadBytes = resData.ioReadBytes;
|
||||||
|
currentInfo.value.ioWriteBytes = resData.ioWriteBytes;
|
||||||
|
currentInfo.value.ioCount = resData.ioCount;
|
||||||
|
currentInfo.value.ioReadTime = resData.ioReadTime;
|
||||||
|
currentInfo.value.ioWriteTime = resData.ioWriteTime;
|
||||||
|
|
||||||
|
currentInfo.value.netBytesSent = resData.netBytesSent;
|
||||||
|
currentInfo.value.netBytesRecv = resData.netBytesRecv;
|
||||||
|
}
|
||||||
|
if (scope === 'gpu') {
|
||||||
|
currentInfo.value.gpuData = resData.gpuData;
|
||||||
|
currentInfo.value.xpuData = resData.xpuData;
|
||||||
|
}
|
||||||
|
if (scope === 'basic') {
|
||||||
|
currentInfo.value.uptime = resData.uptime;
|
||||||
|
currentInfo.value.timeSinceUptime = resData.timeSinceUptime;
|
||||||
|
currentInfo.value.procs = resData.procs;
|
||||||
|
|
||||||
|
currentInfo.value.load1 = resData.load1;
|
||||||
|
currentInfo.value.load5 = resData.load5;
|
||||||
|
currentInfo.value.load15 = resData.load15;
|
||||||
|
currentInfo.value.loadUsagePercent = resData.loadUsagePercent;
|
||||||
|
|
||||||
|
currentInfo.value.cpuPercent = resData.cpuPercent;
|
||||||
|
currentInfo.value.cpuUsedPercent = resData.cpuUsedPercent;
|
||||||
|
currentInfo.value.cpuUsed = resData.cpuUsed;
|
||||||
|
currentInfo.value.cpuTotal = resData.cpuTotal;
|
||||||
|
|
||||||
|
currentInfo.value.memoryTotal = resData.memoryTotal;
|
||||||
|
currentInfo.value.memoryAvailable = resData.memoryAvailable;
|
||||||
|
currentInfo.value.memoryUsed = resData.memoryUsed;
|
||||||
|
currentInfo.value.memoryUsedPercent = resData.memoryUsedPercent;
|
||||||
|
|
||||||
|
currentInfo.value.swapMemoryTotal = resData.swapMemoryTotal;
|
||||||
|
currentInfo.value.swapMemoryAvailable = resData.swapMemoryAvailable;
|
||||||
|
currentInfo.value.swapMemoryUsed = resData.swapMemoryUsed;
|
||||||
|
currentInfo.value.swapMemoryUsedPercent = resData.swapMemoryUsedPercent;
|
||||||
|
|
||||||
|
currentInfo.value.timeSinceUptime = res.data.timeSinceUptime;
|
||||||
|
currentInfo.value.shotTime = resData.shotTime;
|
||||||
|
currentInfo.value.diskData = resData.diskData;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
function loadUpTime(uptime: number) {
|
function loadUpTime(uptime: number) {
|
||||||
if (uptime <= 0) {
|
if (uptime <= 0) {
|
||||||
return '-';
|
return '-';
|
||||||
|
@ -159,7 +159,9 @@
|
|||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
</el-popover>
|
</el-popover>
|
||||||
<span class="input-help">{{ computeSize(item.used) }} / {{ computeSize(item.total) }}</span>
|
<span class="input-help" v-if="chartsOption[`disk${index}`]">
|
||||||
|
{{ computeSize(item.used) }} / {{ computeSize(item.total) }}
|
||||||
|
</span>
|
||||||
</el-col>
|
</el-col>
|
||||||
</template>
|
</template>
|
||||||
<template v-for="(item, index) of currentInfo.gpuData" :key="index">
|
<template v-for="(item, index) of currentInfo.gpuData" :key="index">
|
||||||
@ -385,9 +387,6 @@ const acceptParams = (current: Dashboard.CurrentInfo, base: Dashboard.BaseInfo,
|
|||||||
data: formatNumber(Number(currentInfo.value.gpuData[i].gpuUtil.replaceAll(' %', ''))),
|
data: formatNumber(Number(currentInfo.value.gpuData[i].gpuUtil.replaceAll(' %', ''))),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
if (currentInfo.value.diskData.length + currentInfo.value.gpuData.length > 5) {
|
|
||||||
showMore.value = isInit ? false : showMore.value || false;
|
|
||||||
}
|
|
||||||
currentInfo.value.xpuData = currentInfo.value.xpuData || [];
|
currentInfo.value.xpuData = currentInfo.value.xpuData || [];
|
||||||
for (let i = 0; i < currentInfo.value.xpuData.length; i++) {
|
for (let i = 0; i < currentInfo.value.xpuData.length; i++) {
|
||||||
chartsOption.value['gpu' + i] = {
|
chartsOption.value['gpu' + i] = {
|
||||||
@ -395,6 +394,9 @@ const acceptParams = (current: Dashboard.CurrentInfo, base: Dashboard.BaseInfo,
|
|||||||
data: formatNumber(Number(currentInfo.value.xpuData[i].memoryUtil.replaceAll('%', ''))),
|
data: formatNumber(Number(currentInfo.value.xpuData[i].memoryUtil.replaceAll('%', ''))),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
if (currentInfo.value.diskData.length + currentInfo.value.gpuData.length > 5) {
|
||||||
|
showMore.value = isInit ? false : showMore.value || false;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user