package task import ( "fmt" "eta/mysteel_watch/global" "eta/mysteel_watch/services/alarm_msg" "eta/mysteel_watch/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 + "
" global.LOG.Critical(msg) msg = fmt.Sprintf("The params data is %v", e.params) stack += msg + "
" global.LOG.Critical(msg) msg = fmt.Sprintf("Handler crashed with error %v", err) stack += msg + "
" 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
", file, line)) } fmt.Println("stack:", stack) //go services.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")+";Msg:"+stack, 2) } }() //time.Sleep(60*time.Second) //fmt.Println("i am here new") 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) }