analytic.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package api
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/0xJacky/Nginx-UI/server/tool"
  6. "github.com/shirou/gopsutil/v3/cpu"
  7. "github.com/shirou/gopsutil/v3/disk"
  8. "github.com/shirou/gopsutil/v3/host"
  9. "github.com/shirou/gopsutil/v3/load"
  10. "github.com/shirou/gopsutil/v3/mem"
  11. "github.com/shirou/gopsutil/v3/net"
  12. "net/http"
  13. "runtime"
  14. "strconv"
  15. "time"
  16. "github.com/dustin/go-humanize"
  17. "github.com/gin-gonic/gin"
  18. "github.com/gorilla/websocket"
  19. )
  20. func Analytic(c *gin.Context) {
  21. var upGrader = websocket.Upgrader{
  22. CheckOrigin: func(r *http.Request) bool {
  23. return true
  24. },
  25. }
  26. // upgrade http to websocket
  27. ws, err := upGrader.Upgrade(c.Writer, c.Request, nil)
  28. if err != nil {
  29. return
  30. }
  31. defer ws.Close()
  32. response := make(gin.H)
  33. for {
  34. // read
  35. mt, message, err := ws.ReadMessage()
  36. if err != nil {
  37. break
  38. }
  39. for {
  40. memoryStat, err := mem.VirtualMemory()
  41. if err != nil {
  42. fmt.Println(err)
  43. return
  44. }
  45. response["memory_total"] = humanize.Bytes(memoryStat.Total)
  46. response["memory_used"] = humanize.Bytes(memoryStat.Used)
  47. response["memory_cached"] = humanize.Bytes(memoryStat.Cached)
  48. response["memory_free"] = humanize.Bytes(memoryStat.Free)
  49. response["memory_pressure"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f", memoryStat.UsedPercent), 64)
  50. cpuTimesBefore, _ := cpu.Times(false)
  51. time.Sleep(1000 * time.Millisecond)
  52. cpuTimesAfter, _ := cpu.Times(false)
  53. threadNum := runtime.GOMAXPROCS(0)
  54. cpuUserUsage := (cpuTimesAfter[0].User - cpuTimesBefore[0].User) / (float64(1000*threadNum) / 1000)
  55. cpuSystemUsage := (cpuTimesAfter[0].System - cpuTimesBefore[0].System) / (float64(1000*threadNum) / 1000)
  56. response["cpu_user"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f",
  57. cpuUserUsage*100), 64)
  58. response["cpu_system"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f",
  59. cpuSystemUsage*100), 64)
  60. response["cpu_idle"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f",
  61. (1-cpuUserUsage+cpuSystemUsage)*100), 64)
  62. response["uptime"], _ = host.Uptime()
  63. response["loadavg"], _ = load.Avg()
  64. diskUsage, _ := disk.Usage(".")
  65. response["disk_used"] = humanize.Bytes(diskUsage.Used)
  66. response["disk_total"] = humanize.Bytes(diskUsage.Total)
  67. response["disk_percentage"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f", diskUsage.UsedPercent), 64)
  68. network, _ := net.IOCounters(false)
  69. response["network"] = network
  70. m, _ := json.Marshal(response)
  71. message = m
  72. // write
  73. err = ws.WriteMessage(mt, message)
  74. if err != nil {
  75. break
  76. }
  77. time.Sleep(800 * time.Microsecond)
  78. }
  79. }
  80. }
  81. func GetCpuUsageRecord(c *gin.Context) {
  82. c.JSON(http.StatusOK, gin.H{
  83. "user": tool.CpuUserBuffer,
  84. "total": tool.CpuTotalBuffer,
  85. })
  86. }