forked from TritonDataCenter/containerpilot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
44 lines (38 loc) · 1.16 KB
/
main.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
// ContainerPilot is an init system for cloud-native distributed applications
// that automates the process of service discovery, configuration, and
// lifecycle management inside the container, so you can focus on your apps.
package main // import "github.com/joyent/containerpilot"
import (
"os"
"runtime"
"github.com/joyent/containerpilot/core"
"github.com/joyent/containerpilot/sup"
log "github.com/sirupsen/logrus"
)
// Main executes the containerpilot CLI
func main() {
// make sure we use only a single CPU so as not to cause
// contention on the main application
runtime.GOMAXPROCS(1)
// If we're running as PID1, we fork and run as a supervisor
// so that we can cleanly handle reaping of child processes.
// We fork before doing *anything* else so we don't have to
// worry about where any new threads spawned by the runtime.
if os.Getpid() == 1 {
sup.Run() // blocks forever
return
}
subcommand, params := core.GetArgs()
if subcommand != nil {
err := subcommand(params)
if err != nil {
log.Fatal(err)
}
return
}
app, configErr := core.NewApp(params.ConfigPath)
if configErr != nil {
log.Fatal(configErr)
}
app.Run() // blocks forever
}