cronsun/bin/node/server.go

63 lines
1.3 KiB
Go
Raw Normal View History

2017-01-04 09:27:36 +00:00
// node 服务
// 用于在所需要执行 cron 任务的机器启动服务,替代 cron 执行所需的任务
package main
import (
"flag"
"runtime"
"sunteng/commons/log"
2017-05-09 10:27:32 +00:00
"github.com/shunfei/cronsun/conf"
2017-05-10 12:04:11 +00:00
"github.com/shunfei/cronsun/event"
2017-05-09 10:27:32 +00:00
"github.com/shunfei/cronsun/models"
"github.com/shunfei/cronsun/node"
2017-01-04 09:27:36 +00:00
)
var (
gomax = flag.Int("gomax",
4, "GOMAXPROCS: the max number of operating system threads that can execute")
)
func main() {
flag.Parse()
//set cpu usage
runtime.GOMAXPROCS(*gomax)
2017-01-09 10:51:52 +00:00
if err := models.Init(); err != nil {
2017-01-04 09:27:36 +00:00
log.Error(err.Error())
return
}
2017-01-06 08:44:42 +00:00
n, err := node.NewNode(conf.Config)
2017-01-05 02:37:48 +00:00
if err != nil {
log.Error(err.Error())
return
2017-01-04 09:27:36 +00:00
}
2017-01-05 02:37:48 +00:00
if err = n.Register(); err != nil {
log.Error(err.Error())
return
}
2017-03-08 09:00:22 +00:00
if err = models.StartProc(); err != nil {
log.Warnf("[process key will not timeout]proc lease id set err: %s", err.Error())
}
if err = n.Run(); err != nil {
log.Error(err.Error())
return
}
2017-01-05 02:37:48 +00:00
2017-01-06 08:44:42 +00:00
log.Noticef("cronsun %s service started, Ctrl+C or send kill sign to exit", n.String())
2017-01-04 09:27:36 +00:00
// 注册退出事件
2017-03-08 09:00:22 +00:00
event.On(event.EXIT, n.Stop, conf.Exit, models.Exit)
// 注册监听配置更新事件
event.On(event.WAIT, models.Reload)
2017-01-04 09:27:36 +00:00
// 监听退出信号
event.Wait()
// 处理退出事件
event.Emit(event.EXIT, nil)
log.Notice("exit success")
}