func main() { app := cli.NewApp() app.Name = path.Base(os.Args[0]) app.Usage = "a Docker-native clustering system" app.Version = version.VERSION + " (" + version.GITCOMMIT + ")" app.Author = "" app.Email = "" app.Flags = []cli.Flag{ cli.BoolFlag{ Name: "debug", Usage: "debug mode", EnvVar: "DEBUG", }, cli.StringFlag{ Name: "log-level, l", Value: "info", Usage: fmt.Sprintf("Log level (options: debug, info, warn, error, fatal, panic)"), }, } // logs app.Before = func(c *cli.Context) error { log.SetOutput(os.Stderr) level, err := log.ParseLevel(c.String("log-level")) if err != nil { log.Fatalf(err.Error()) } log.SetLevel(level) // If a log level wasn't specified and we are running in debug mode, // enforce log-level=debug. if !c.IsSet("log-level") && !c.IsSet("l") && c.Bool("debug") { log.SetLevel(log.DebugLevel) } return nil } app.Commands = []cli.Command{ { Name: "create", ShortName: "c", Usage: "create a cluster", Action: func(c *cli.Context) { discovery := &token.TokenDiscoveryService{} discovery.Initialize("", 0) token, err := discovery.CreateCluster() if err != nil { log.Fatal(err) } fmt.Println(token) }, }, { Name: "list", ShortName: "l", Usage: "list nodes in a cluster", Action: func(c *cli.Context) { dflag := getDiscovery(c) if dflag == "" { log.Fatalf("discovery required to list a cluster. See '%s list --help'.", c.App.Name) } d, err := discovery.New(dflag, 0) if err != nil { log.Fatal(err) } nodes, err := d.Fetch() if err != nil { log.Fatal(err) } for _, node := range nodes { fmt.Println(node) } }, }, { Name: "manage", ShortName: "m", Usage: "manage a docker cluster", Flags: []cli.Flag{ flStore, flStrategy, flFilter, flHosts, flHeartBeat, flOverCommit, flTls, flTlsCaCert, flTlsCert, flTlsKey, flTlsVerify, flEnableCors}, Action: manage, }, { Name: "join", ShortName: "j", Usage: "join a docker cluster", Flags: []cli.Flag{flAddr, flHeartBeat}, Action: join, }, } if err := app.Run(os.Args); err != nil { log.Fatal(err) } }
func main() { app := cli.NewApp() app.Name = "swarm" app.Usage = "docker clustering" app.Version = "0.0.1" app.Flags = []cli.Flag{ cli.BoolFlag{ Name: "debug", Usage: "debug mode", EnvVar: "DEBUG", }, } // logs app.Before = func(c *cli.Context) error { log.SetOutput(os.Stderr) if c.Bool("debug") { log.SetLevel(log.DebugLevel) } return nil } // flags flToken := cli.StringFlag{ Name: "token", Value: "", Usage: "cluster token", EnvVar: "SWARM_TOKEN", } flAddr := cli.StringFlag{ Name: "addr", Value: "127.0.0.1:4243", Usage: "ip to advertise", EnvVar: "SWARM_ADDR", } flHeartBeat := cli.IntFlag{ Name: "heartbeat, hb", Value: 25, Usage: "time in second between each heartbeat", } flEnableCors := cli.BoolFlag{ Name: "api-enable-cors, cors", Usage: "enable CORS headers in the remote API", } app.Commands = []cli.Command{ { Name: "create", ShortName: "c", Usage: "create a cluster", Action: func(c *cli.Context) { token, err := discovery.CreateCluster() if err != nil { log.Fatal(err) } fmt.Println(token) }, }, { Name: "list", ShortName: "l", Usage: "list nodes in a cluster", Flags: []cli.Flag{flToken}, Action: func(c *cli.Context) { if c.String("token") == "" { log.Fatal("--token required to list a cluster") } nodes, err := discovery.FetchSlaves(c.String("token")) if err != nil { log.Fatal(err) } for _, node := range nodes { fmt.Println(node) } }, }, { Name: "manage", ShortName: "m", Usage: "manage a docker cluster", Flags: []cli.Flag{flToken, flAddr, flHeartBeat, flEnableCors}, Action: manage, }, { Name: "join", ShortName: "j", Usage: "join a docker cluster", Flags: []cli.Flag{flToken, flAddr, flHeartBeat}, Action: join, }, } if err := app.Run(os.Args); err != nil { log.Fatal(err) } }
// Run the Swarm CLI. func Run() { app := cli.NewApp() app.Name = path.Base(os.Args[0]) app.Usage = "A Docker-native clustering system" app.Version = version.VERSION + " (" + version.GITCOMMIT + ")" app.Author = "" app.Email = "" app.Flags = []cli.Flag{ cli.BoolFlag{ Name: "debug", Usage: "debug mode", EnvVar: "DEBUG", }, cli.StringFlag{ Name: "log-level, l", Value: "info", Usage: fmt.Sprintf("Log level (options: debug, info, warn, error, fatal, panic)"), }, } // logs app.Before = func(c *cli.Context) error { log.SetOutput(os.Stderr) level, err := log.ParseLevel(c.String("log-level")) if err != nil { log.Fatalf(err.Error()) } log.SetLevel(level) // If a log level wasn't specified and we are running in debug mode, // enforce log-level=debug. if !c.IsSet("log-level") && !c.IsSet("l") && c.Bool("debug") { log.SetLevel(log.DebugLevel) } return nil } app.Commands = []cli.Command{ { Name: "create", ShortName: "c", Usage: "Create a cluster", Action: func(c *cli.Context) { if len(c.Args()) != 0 { log.Fatalf("the `create` command takes no arguments. See '%s create --help'.", c.App.Name) } discovery := &token.Discovery{} discovery.Initialize("", 0, 0) token, err := discovery.CreateCluster() if err != nil { log.Fatal(err) } fmt.Println(token) }, }, { Name: "list", ShortName: "l", Usage: "List nodes in a cluster", Flags: []cli.Flag{flTimeout}, Action: func(c *cli.Context) { dflag := getDiscovery(c) if dflag == "" { log.Fatalf("discovery required to list a cluster. See '%s list --help'.", c.App.Name) } timeout, err := time.ParseDuration(c.String("timeout")) if err != nil { log.Fatalf("invalid --timeout: %v", err) } d, err := discovery.New(dflag, timeout, 0) if err != nil { log.Fatal(err) } ch, errCh := d.Watch(nil) select { case entries := <-ch: for _, entry := range entries { fmt.Println(entry) } case err := <-errCh: log.Fatal(err) case <-time.After(timeout): log.Fatal("Timed out") } }, }, { Name: "manage", ShortName: "m", Usage: "Manage a docker cluster", Flags: []cli.Flag{ flStore, flStrategy, flFilter, flHosts, flLeaderElection, flAddr, flTLS, flTLSCaCert, flTLSCert, flTLSKey, flTLSVerify, flHeartBeat, flEnableCors, flCluster, flClusterOpt}, Action: manage, }, { Name: "join", ShortName: "j", Usage: "join a docker cluster", Flags: []cli.Flag{flAddr, flHeartBeat, flTTL}, Action: join, }, } if err := app.Run(os.Args); err != nil { log.Fatal(err) } }