1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- package task
- import (
- "fmt"
- "hongze/hongze_yb/global"
- "hongze/hongze_yb/services/alarm_msg"
- "hongze/hongze_yb/utils"
- "os"
- "runtime"
- "sync"
- "time"
- )
- type TaskFunc func(params ...interface{})
- var taskList chan *Executor
- var once sync.Once
- func GetTaskList() chan *Executor {
- once.Do(func() {
- taskList = make(chan *Executor, 1000)
- })
- return taskList
- }
- type Executor struct {
- f TaskFunc
- params []interface{}
- }
- func (e *Executor) Exec() {
- go func() {
- defer func() {
- if err := recover(); err !=nil {
- stack := ""
- msg := fmt.Sprintf("当前进程pid:%d; 父进程ppid:%d", os.Getpid(), os.Getppid())
- stack += msg + "</br>"
- global.LOG.Critical(msg)
- msg = fmt.Sprintf("The params data is %v", e.params)
- stack += msg + "</br>"
- global.LOG.Critical(msg)
- msg = fmt.Sprintf("Handler crashed with error %v", err)
- stack += msg + "</br>"
- global.LOG.Critical(msg)
- for i := 1; ; i++ {
- _, file, line, ok := runtime.Caller(i)
- if !ok {
- break
- }
- global.LOG.Critical(fmt.Sprintf("%s:%d", file, line))
- stack = stack + fmt.Sprintln(fmt.Sprintf("%s:%d</br>", file, line))
- }
- fmt.Println("stack:", stack)
-
- go alarm_msg.SendAlarmMsg(utils.APPNAME+"崩了"+time.Now().Format("2006-01-02 15:04:05")+";Msg:"+stack, 2)
- }
- }()
-
-
- e.f(e.params...)
- }()
- }
- func NewExecutor(f TaskFunc, params []interface{}) *Executor {
- return &Executor{f: f, params: params}
- }
- func Task(f TaskFunc, params ...interface{}) {
- taskList <- NewExecutor(f, params)
- }
|