123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- 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 + "</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 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)
- }
|