2017-01-04 09:27:36 +00:00
|
|
|
// node 服务
|
|
|
|
// 用于在所需要执行 cron 任务的机器启动服务,替代 cron 执行所需的任务
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
2017-05-12 08:47:13 +00:00
|
|
|
slog "log"
|
|
|
|
|
|
|
|
"go.uber.org/zap"
|
|
|
|
"go.uber.org/zap/zapcore"
|
2017-01-04 09:27:36 +00:00
|
|
|
|
2017-05-12 06:48:24 +00:00
|
|
|
"github.com/shunfei/cronsun"
|
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-12 07:38:50 +00:00
|
|
|
"github.com/shunfei/cronsun/log"
|
2017-05-09 10:27:32 +00:00
|
|
|
"github.com/shunfei/cronsun/node"
|
2017-01-04 09:27:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2017-06-30 01:53:47 +00:00
|
|
|
level = flag.Int("l", 0, "log level, -1:debug, 0:info, 1:warn, 2:error")
|
2017-01-04 09:27:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
2017-05-12 08:47:13 +00:00
|
|
|
|
|
|
|
lcf := zap.NewDevelopmentConfig()
|
|
|
|
lcf.Level.SetLevel(zapcore.Level(*level))
|
|
|
|
lcf.Development = false
|
2017-06-30 01:53:47 +00:00
|
|
|
logger, err := lcf.Build(zap.AddCallerSkip(1))
|
2017-05-12 08:47:13 +00:00
|
|
|
if err != nil {
|
|
|
|
slog.Fatalln("new log err:", err.Error())
|
|
|
|
}
|
|
|
|
log.SetLogger(logger.Sugar())
|
2017-01-04 09:27:36 +00:00
|
|
|
|
2017-05-12 06:48:24 +00:00
|
|
|
if err := cronsun.Init(); err != nil {
|
2017-05-12 07:38:50 +00:00
|
|
|
log.Errorf(err.Error())
|
2017-01-04 09:27:36 +00:00
|
|
|
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 {
|
2017-05-12 07:38:50 +00:00
|
|
|
log.Errorf(err.Error())
|
2017-01-05 02:37:48 +00:00
|
|
|
return
|
2017-01-04 09:27:36 +00:00
|
|
|
}
|
|
|
|
|
2017-01-05 02:37:48 +00:00
|
|
|
if err = n.Register(); err != nil {
|
2017-05-12 07:38:50 +00:00
|
|
|
log.Errorf(err.Error())
|
2017-01-05 02:37:48 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2017-05-12 06:48:24 +00:00
|
|
|
if err = cronsun.StartProc(); err != nil {
|
2017-03-08 09:00:22 +00:00
|
|
|
log.Warnf("[process key will not timeout]proc lease id set err: %s", err.Error())
|
|
|
|
}
|
|
|
|
|
2017-01-12 07:34:13 +00:00
|
|
|
if err = n.Run(); err != nil {
|
2017-05-12 07:38:50 +00:00
|
|
|
log.Errorf(err.Error())
|
2017-01-12 07:34:13 +00:00
|
|
|
return
|
|
|
|
}
|
2017-01-05 02:37:48 +00:00
|
|
|
|
2017-05-12 07:38:50 +00:00
|
|
|
log.Infof("cronsun %s service started, Ctrl+C or send kill sign to exit", n.String())
|
2017-01-04 09:27:36 +00:00
|
|
|
// 注册退出事件
|
2017-05-12 06:48:24 +00:00
|
|
|
event.On(event.EXIT, n.Stop, conf.Exit, cronsun.Exit)
|
2017-03-08 09:00:22 +00:00
|
|
|
// 注册监听配置更新事件
|
2017-05-12 06:48:24 +00:00
|
|
|
event.On(event.WAIT, cronsun.Reload)
|
2017-01-04 09:27:36 +00:00
|
|
|
// 监听退出信号
|
|
|
|
event.Wait()
|
|
|
|
// 处理退出事件
|
|
|
|
event.Emit(event.EXIT, nil)
|
2017-05-12 07:38:50 +00:00
|
|
|
log.Infof("exit success")
|
2017-01-04 09:27:36 +00:00
|
|
|
}
|