analytic.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. package api
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "github.com/0xJacky/Nginx-UI/tool"
  6. "github.com/dustin/go-humanize"
  7. "github.com/gin-gonic/gin"
  8. "github.com/gorilla/websocket"
  9. "github.com/mackerelio/go-osstat/cpu"
  10. "github.com/mackerelio/go-osstat/memory"
  11. "github.com/mackerelio/go-osstat/uptime"
  12. "github.com/mackerelio/go-osstat/loadavg"
  13. "net/http"
  14. "strconv"
  15. "time"
  16. )
  17. var upGrader = websocket.Upgrader{
  18. CheckOrigin: func(r *http.Request) bool {
  19. return true
  20. },
  21. }
  22. func Analytic(c *gin.Context) {
  23. // upgrade http to websocket
  24. ws, err := upGrader.Upgrade(c.Writer, c.Request, nil)
  25. if err != nil {
  26. return
  27. }
  28. defer ws.Close()
  29. for {
  30. // read
  31. mt, message, err := ws.ReadMessage()
  32. if err != nil {
  33. break
  34. }
  35. if string(message) == "ping" {
  36. response := make(gin.H)
  37. memoryStat, err := memory.Get()
  38. if err != nil {
  39. fmt.Println(err)
  40. return
  41. }
  42. response["memory_total"] = humanize.Bytes(memoryStat.Total)
  43. response["memory_used"] = humanize.Bytes(memoryStat.Used)
  44. response["memory_cached"] = humanize.Bytes(memoryStat.Cached)
  45. response["memory_free"] = humanize.Bytes(memoryStat.Free)
  46. response["memory_pressure"] = memoryStat.Used * 100 / memoryStat.Total
  47. before, err := cpu.Get()
  48. if err != nil {
  49. fmt.Println(err)
  50. }
  51. time.Sleep(time.Duration(1) * time.Second)
  52. after, err := cpu.Get()
  53. if err != nil {
  54. fmt.Println(err)
  55. }
  56. total := float64(after.Total - before.Total)
  57. response["cpu_user"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f",
  58. float64(after.User-before.User)/total*100), 64)
  59. response["cpu_system"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f",
  60. float64(after.System-before.System)/total*100), 64)
  61. response["cpu_idle"], _ = strconv.ParseFloat(fmt.Sprintf("%.2f",
  62. float64(after.Idle-before.Idle)/total*100), 64)
  63. response["uptime"], _ = uptime.Get()
  64. response["uptime"] = response["uptime"].(time.Duration) / time.Second
  65. response["loadavg"], _ = loadavg.Get()
  66. used, _total, percentage, err := tool.DiskUsage(".")
  67. response["disk_used"] = used
  68. response["disk_total"] = _total
  69. response["disk_percentage"] = percentage
  70. if err != nil {
  71. fmt.Println(err)
  72. return
  73. }
  74. m, err := json.Marshal(response)
  75. if err != nil {
  76. fmt.Println(err)
  77. return
  78. }
  79. message = m
  80. }
  81. // write
  82. err = ws.WriteMessage(mt, message)
  83. if err != nil {
  84. break
  85. }
  86. }
  87. }