12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- package main
- import (
- "eta_gn/eta_api/controllers"
- "eta_gn/eta_api/models"
- "eta_gn/eta_api/services/alarm_msg"
- "fmt"
- "runtime"
- "time"
- _ "eta_gn/eta_api/global"
- _ "eta_gn/eta_api/routers"
- "eta_gn/eta_api/services"
- "eta_gn/eta_api/utils"
- "github.com/beego/beego/v2/adapter/logs"
- "github.com/beego/beego/v2/server/web"
- "github.com/beego/beego/v2/server/web/context"
- )
- func main() {
- if web.BConfig.RunMode == "dev" {
- web.BConfig.WebConfig.DirectoryIndex = true
- web.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
- }
- go services.Task()
- // 初始化表数据入库
- models.AfterInitTable()
- // 异常处理
- web.ErrorController(&controllers.ErrorController{})
- // 内存调整
- web.BConfig.MaxMemory = 1024 * 1024 * 128
- web.BConfig.RecoverFunc = Recover
- web.Run()
- }
- func Recover(ctx *context.Context, conf *web.Config) {
- if err := recover(); err != nil {
- if err == web.ErrAbort {
- return
- }
- if !web.BConfig.RecoverPanic {
- panic(err)
- }
- stack := ""
- msg := fmt.Sprintf("The request url is %v", ctx.Input.URL())
- stack += msg + "</br>"
- logs.Critical(msg)
- msg = fmt.Sprintf("The request data is %v", string(ctx.Input.RequestBody))
- stack += msg + "</br>"
- logs.Critical(msg)
- msg = fmt.Sprintf("Handler crashed with error %v", err)
- stack += msg + "</br>"
- logs.Critical(msg)
- for i := 1; ; i++ {
- _, file, line, ok := runtime.Caller(i)
- if !ok {
- break
- }
- logs.Critical(fmt.Sprintf("%s:%d", file, line))
- stack = stack + fmt.Sprintln(fmt.Sprintf("%s:%d</br>", file, line))
- }
- go alarm_msg.SendAlarmMsg(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05")+"<br/>"+stack, 3)
- }
- return
- }
|