init.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. package swarm
  2. import (
  3. "fmt"
  4. "golang.org/x/net/context"
  5. "github.com/docker/docker/api/client"
  6. "github.com/docker/docker/cli"
  7. "github.com/docker/engine-api/types/swarm"
  8. "github.com/spf13/cobra"
  9. "github.com/spf13/pflag"
  10. )
  11. type initOptions struct {
  12. swarmOptions
  13. listenAddr NodeAddrOption
  14. forceNewCluster bool
  15. }
  16. func newInitCommand(dockerCli *client.DockerCli) *cobra.Command {
  17. opts := initOptions{
  18. listenAddr: NewListenAddrOption(),
  19. swarmOptions: swarmOptions{
  20. autoAccept: NewAutoAcceptOption(),
  21. },
  22. }
  23. cmd := &cobra.Command{
  24. Use: "init",
  25. Short: "Initialize a Swarm",
  26. Args: cli.NoArgs,
  27. RunE: func(cmd *cobra.Command, args []string) error {
  28. return runInit(dockerCli, cmd.Flags(), opts)
  29. },
  30. }
  31. flags := cmd.Flags()
  32. flags.Var(&opts.listenAddr, "listen-addr", "Listen address")
  33. flags.BoolVar(&opts.forceNewCluster, "force-new-cluster", false, "Force create a new cluster from current state.")
  34. addSwarmFlags(flags, &opts.swarmOptions)
  35. return cmd
  36. }
  37. func runInit(dockerCli *client.DockerCli, flags *pflag.FlagSet, opts initOptions) error {
  38. client := dockerCli.Client()
  39. ctx := context.Background()
  40. req := swarm.InitRequest{
  41. ListenAddr: opts.listenAddr.String(),
  42. ForceNewCluster: opts.forceNewCluster,
  43. Spec: opts.swarmOptions.ToSpec(),
  44. }
  45. nodeID, err := client.SwarmInit(ctx, req)
  46. if err != nil {
  47. return err
  48. }
  49. fmt.Printf("Swarm initialized: current node (%s) is now a manager.\n", nodeID)
  50. return nil
  51. }