main.go 1.8 KB

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