fiber/middleware/monitor/monitor.go

74 lines
1.3 KiB
Go

package monitor
import (
"os"
"sync"
"time"
"github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/internal/gopsutil/process"
)
type stats struct {
CPU float64 `json:"cpu"`
RAM uint64 `json:"ram"`
Load float64 `json:"load"`
Time int64 `json:"time"`
Reqs uint32 `json:"reqs"`
}
var (
monitorCPU float64
monitorRAM uint64
)
var (
mutex sync.RWMutex
once sync.Once
data = &stats{}
)
// New creates a new middleware handler
func New() fiber.Handler {
// Start routine to update statistics
once.Do(func() {
go monitor()
})
// Return new handler
return func(c *fiber.Ctx) error {
// Call chain
if err := c.Next(); err != nil {
return err
}
if c.Get(fiber.HeaderAccept) == fiber.MIMEApplicationJSON {
mutex.Lock()
data = &stats{
CPU: monitorCPU,
RAM: monitorRAM,
Load: 2.32,
Time: (time.Now().UnixNano() - c.Context().Time().UnixNano()) / 100000,
Reqs: c.App().Server().GetCurrentConcurrency(),
}
mutex.Unlock()
return c.JSON(data)
}
c.Response().Header.SetContentType(fiber.MIMETextHTMLCharsetUTF8)
return c.Send(index)
}
}
func monitor() {
p, _ := process.NewProcess(int32(os.Getpid()))
for {
cpu, _ := p.CPUPercent()
monitorCPU = cpu / 10
mem, _ := p.MemoryInfo()
monitorRAM = mem.RSS
time.Sleep(1 * time.Second)
}
}