You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
1.1 KiB
59 lines
1.1 KiB
package main |
|
|
|
import ( |
|
"flag" |
|
"os" |
|
"os/signal" |
|
"syscall" |
|
"time" |
|
|
|
"go-common/app/job/main/playlist/conf" |
|
"go-common/app/job/main/playlist/http" |
|
"go-common/app/job/main/playlist/service" |
|
"go-common/library/log" |
|
"go-common/library/net/trace" |
|
) |
|
|
|
func main() { |
|
flag.Parse() |
|
initConf() |
|
initLog() |
|
defer log.Close() |
|
log.Info("playlist-job start") |
|
srv := service.New(conf.Conf) |
|
http.Init(conf.Conf, srv) |
|
initSignal(srv) |
|
} |
|
|
|
func initConf() { |
|
if err := conf.Init(); err != nil { |
|
panic(err) |
|
} |
|
} |
|
|
|
func initLog() { |
|
log.Init(conf.Conf.Log) |
|
trace.Init(conf.Conf.Tracer) |
|
defer trace.Close() |
|
} |
|
|
|
func initSignal(srv *service.Service) { |
|
c := make(chan os.Signal, 1) |
|
signal.Notify(c, syscall.SIGHUP, syscall.SIGQUIT, syscall.SIGTERM, syscall.SIGINT) |
|
for { |
|
s := <-c |
|
log.Info("playlist-job get a signal: %s", s.String()) |
|
switch s { |
|
case syscall.SIGQUIT, syscall.SIGTERM, syscall.SIGINT: |
|
if err := srv.Close(); err != nil { |
|
log.Error("srv close consumer error(%v)", err) |
|
} |
|
time.Sleep(time.Second) |
|
return |
|
case syscall.SIGHUP: |
|
// TODO: reload |
|
default: |
|
return |
|
} |
|
} |
|
}
|
|
|