main.go 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package main
  2. import (
  3. "eta/eta_chart_lib/controllers"
  4. _ "eta/eta_chart_lib/facade/instance"
  5. "eta/eta_chart_lib/models"
  6. _ "eta/eta_chart_lib/routers"
  7. "eta/eta_chart_lib/services/alarm_msg"
  8. "eta/eta_chart_lib/utils"
  9. "fmt"
  10. "github.com/beego/beego/v2/adapter/logs"
  11. beego "github.com/beego/beego/v2/server/web"
  12. "github.com/beego/beego/v2/server/web/context"
  13. "runtime"
  14. "time"
  15. )
  16. func main() {
  17. if beego.BConfig.RunMode == "dev" {
  18. beego.BConfig.WebConfig.DirectoryIndex = true
  19. beego.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
  20. }
  21. // 初始化表数据入库
  22. models.AfterInitTable()
  23. // 异常处理
  24. beego.ErrorController(&controllers.ErrorController{})
  25. beego.BConfig.RecoverFunc = Recover
  26. beego.Run()
  27. }
  28. func Recover(ctx *context.Context, conf *beego.Config) {
  29. if err := recover(); err != nil {
  30. if err == beego.ErrAbort {
  31. return
  32. }
  33. if !beego.BConfig.RecoverPanic {
  34. panic(err)
  35. }
  36. stack := ""
  37. msg := fmt.Sprintf("The request url is %v", ctx.Input.URL())
  38. stack += msg + "</br>"
  39. logs.Critical(msg)
  40. msg = fmt.Sprintf("The request data is %v", string(ctx.Input.RequestBody))
  41. stack += msg + "</br>"
  42. logs.Critical(msg)
  43. msg = fmt.Sprintf("Handler crashed with error %v", err)
  44. stack += msg + "</br>"
  45. logs.Critical(msg)
  46. for i := 1; ; i++ {
  47. _, file, line, ok := runtime.Caller(i)
  48. if !ok {
  49. break
  50. }
  51. logs.Critical(fmt.Sprintf("%s:%d", file, line))
  52. stack = stack + fmt.Sprintln(fmt.Sprintf("%s:%d</br>", file, line))
  53. }
  54. //go utils.SendEmail(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05"), stack, utils.EmailSendToUsers)
  55. go alarm_msg.SendAlarmMsg(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05")+"<br/>"+stack, 3)
  56. }
  57. return
  58. }