-
Notifications
You must be signed in to change notification settings - Fork 12
/
main_linux.go
124 lines (101 loc) · 2.52 KB
/
main_linux.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// +build !darwin
package main
import (
"flag"
"io/ioutil"
"net/http"
_ "net/http/pprof"
"os"
"runtime"
"runtime/debug"
"syscall"
"github.com/sevlyar/go-daemon"
log "github.com/sirupsen/logrus"
"github.com/aerospike-community/amc/common"
"github.com/aerospike-community/amc/controllers"
)
var (
configFile = flag.String("config-file", "/etc/amc/amc.conf", "Configuration file.")
configDir = flag.String("config-dir", "/etc/amc/", "Configuration dir.")
profileMode = flag.Bool("profile", false, "Run benchmarks with profiler active on port 6060.")
daemonMode = flag.Bool("daemon", false, "Run AMC in daemon mode.")
daemonSignal = flag.String("signal", "", `send signal to the daemon
stop — graceful shutdown.`)
)
func main() {
defer func() {
if err := recover(); err != nil {
log.Fatal(string(debug.Stack()))
}
}()
runtime.GOMAXPROCS(runtime.NumCPU())
flag.Parse()
if *daemonSignal == "stop" {
log.SetOutput(ioutil.Discard)
}
// launch profiler if in profile mode
if *profileMode {
go func() {
log.Println(http.ListenAndServe(":6060", nil))
}()
}
log.Infof("Trying to start the AMC server...")
config := common.Config{}
common.InitConfig(*configFile, *configDir, &config)
// close the log file on exit
defer func() {
if config.LogFile != nil {
config.LogFile.Close()
}
}()
/*
manage daemon
*/
daemon.AddCommand(daemon.StringFlag(daemonSignal, "stop"), syscall.SIGTERM, shutdownHandler)
cntxt := &daemon.Context{
PidFileName: config.AMC.PIDFile,
PidFilePerm: 0644,
LogFileName: config.AMC.ErrorLog,
LogFilePerm: 0640,
WorkDir: config.AMC.Chdir,
Umask: 027,
Args: flag.Args(),
}
if len(daemon.ActiveFlags()) > 0 {
d, err := cntxt.Search()
if err != nil {
log.Fatalln("Unable to send signal to the daemon:", err)
}
if err := daemon.SendCommands(d); err != nil {
log.Fatalln(err)
}
return
}
if *daemonMode {
d, err := cntxt.Reborn()
if err != nil {
log.Fatalln(err)
}
if d != nil {
return
}
defer cntxt.Release()
common.SetupDatabase(config.AMC.Database)
log.Infoln("Starting AMC daemon...")
go controllers.Server(&config)
log.Infoln("AMC daemon started.")
err = daemon.ServeSignals()
if err != nil {
log.Errorln("Error: ", err)
}
log.Println("daemon terminated.")
} else {
common.SetupDatabase(config.AMC.Database)
controllers.Server(&config)
}
}
func shutdownHandler(sig os.Signal) error {
log.Println("Shutting down AMC gracefully...")
controllers.ShutdownServer()
return daemon.ErrStop
}