|
@@ -1,9 +1,14 @@
|
|
|
package main
|
|
|
|
|
|
import (
|
|
|
+ "eta/eta_mini_bridge/controllers"
|
|
|
_ "eta/eta_mini_bridge/routers"
|
|
|
+ "fmt"
|
|
|
+ "runtime"
|
|
|
|
|
|
+ "github.com/beego/beego/v2/core/logs"
|
|
|
"github.com/beego/beego/v2/server/web"
|
|
|
+ "github.com/beego/beego/v2/server/web/context"
|
|
|
)
|
|
|
|
|
|
func main() {
|
|
@@ -11,5 +16,43 @@ func main() {
|
|
|
web.BConfig.WebConfig.DirectoryIndex = true
|
|
|
web.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
|
|
|
}
|
|
|
+
|
|
|
+ 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 utils.SendEmail(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05"), stack, utils.EmailSendToUsers)
|
|
|
+ // go alarm_msg.SendAlarmMsg(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05")+"<br/>"+stack, 3)
|
|
|
+ }
|
|
|
+ return
|
|
|
+}
|