Tizen_4.0 base
[platform/upstream/docker-engine.git] / vendor / github.com / opencontainers / runc / main.go
1 package runc
2
3 import (
4         "fmt"
5         "io"
6         "os"
7         "strings"
8
9         "github.com/Sirupsen/logrus"
10         "github.com/opencontainers/runtime-spec/specs-go"
11         "github.com/urfave/cli"
12 )
13
14 // version will be populated by the Makefile, read from
15 // VERSION file of the source code.
16 var version = ""
17
18 // gitCommit will be the hash that the binary was built from
19 // and will be populated by the Makefile
20 var gitCommit = ""
21
22 const (
23         specConfig = "config.json"
24         usage      = `Open Container Initiative runtime
25
26 runc is a command line client for running applications packaged according to
27 the Open Container Initiative (OCI) format and is a compliant implementation of the
28 Open Container Initiative specification.
29
30 runc integrates well with existing process supervisors to provide a production
31 container runtime environment for applications. It can be used with your
32 existing process monitoring tools and the container will be spawned as a
33 direct child of the process supervisor.
34
35 Containers are configured using bundles. A bundle for a container is a directory
36 that includes a specification file named "` + specConfig + `" and a root filesystem.
37 The root filesystem contains the contents of the container.
38
39 To start a new instance of a container:
40
41     # runc run [ -b bundle ] <container-id>
42
43 Where "<container-id>" is your name for the instance of the container that you
44 are starting. The name you provide for the container instance must be unique on
45 your host. Providing the bundle directory using "-b" is optional. The default
46 value for "bundle" is the current directory.`
47 )
48
49 func Main() {
50         app := cli.NewApp()
51         app.Name = "runc"
52         app.Usage = usage
53
54         var v []string
55         if version != "" {
56                 v = append(v, version)
57         }
58         if gitCommit != "" {
59                 v = append(v, fmt.Sprintf("commit: %s", gitCommit))
60         }
61         v = append(v, fmt.Sprintf("spec: %s", specs.Version))
62         app.Version = strings.Join(v, "\n")
63         app.Flags = []cli.Flag{
64                 cli.BoolFlag{
65                         Name:  "debug",
66                         Usage: "enable debug output for logging",
67                 },
68                 cli.StringFlag{
69                         Name:  "log",
70                         Value: "/dev/null",
71                         Usage: "set the log file path where internal debug information is written",
72                 },
73                 cli.StringFlag{
74                         Name:  "log-format",
75                         Value: "text",
76                         Usage: "set the format used by logs ('text' (default), or 'json')",
77                 },
78                 cli.StringFlag{
79                         Name:  "root",
80                         Value: "/run/runc",
81                         Usage: "root directory for storage of container state (this should be located in tmpfs)",
82                 },
83                 cli.StringFlag{
84                         Name:  "criu",
85                         Value: "criu",
86                         Usage: "path to the criu binary used for checkpoint and restore",
87                 },
88                 cli.BoolFlag{
89                         Name:  "systemd-cgroup",
90                         Usage: "enable systemd cgroup support, expects cgroupsPath to be of form \"slice:prefix:name\" for e.g. \"system.slice:runc:434234\"",
91                 },
92         }
93         app.Commands = []cli.Command{
94                 checkpointCommand,
95                 createCommand,
96                 deleteCommand,
97                 eventsCommand,
98                 execCommand,
99                 initCommand,
100                 killCommand,
101                 listCommand,
102                 pauseCommand,
103                 psCommand,
104                 restoreCommand,
105                 resumeCommand,
106                 runCommand,
107                 specCommand,
108                 startCommand,
109                 stateCommand,
110                 updateCommand,
111         }
112         app.Before = func(context *cli.Context) error {
113                 if context.GlobalBool("debug") {
114                         logrus.SetLevel(logrus.DebugLevel)
115                 }
116                 if path := context.GlobalString("log"); path != "" {
117                         f, err := os.OpenFile(path, os.O_CREATE|os.O_WRONLY|os.O_APPEND|os.O_SYNC, 0666)
118                         if err != nil {
119                                 return err
120                         }
121                         logrus.SetOutput(f)
122                 }
123                 switch context.GlobalString("log-format") {
124                 case "text":
125                         // retain logrus's default.
126                 case "json":
127                         logrus.SetFormatter(new(logrus.JSONFormatter))
128                 default:
129                         return fmt.Errorf("unknown log-format %q", context.GlobalString("log-format"))
130                 }
131                 return nil
132         }
133         // If the command returns an error, cli takes upon itself to print
134         // the error on cli.ErrWriter and exit.
135         // Use our own writer here to ensure the log gets sent to the right location.
136         cli.ErrWriter = &FatalWriter{cli.ErrWriter}
137         if err := app.Run(os.Args); err != nil {
138                 fatal(err)
139         }
140 }
141
142 type FatalWriter struct {
143         cliErrWriter io.Writer
144 }
145
146 func (f *FatalWriter) Write(p []byte) (n int, err error) {
147         logrus.Error(string(p))
148         return f.cliErrWriter.Write(p)
149 }