docker.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package main
  2. import (
  3. "fmt"
  4. "os"
  5. "github.com/docker/docker/cli"
  6. "github.com/docker/docker/daemon/config"
  7. "github.com/docker/docker/dockerversion"
  8. "github.com/docker/docker/pkg/jsonmessage"
  9. "github.com/docker/docker/pkg/reexec"
  10. "github.com/docker/docker/pkg/term"
  11. "github.com/moby/buildkit/util/apicaps"
  12. "github.com/sirupsen/logrus"
  13. "github.com/spf13/cobra"
  14. )
  15. func newDaemonCommand() (*cobra.Command, error) {
  16. opts := newDaemonOptions(config.New())
  17. cmd := &cobra.Command{
  18. Use: "dockerd [OPTIONS]",
  19. Short: "A self-sufficient runtime for containers.",
  20. SilenceUsage: true,
  21. SilenceErrors: true,
  22. Args: cli.NoArgs,
  23. RunE: func(cmd *cobra.Command, args []string) error {
  24. opts.flags = cmd.Flags()
  25. return runDaemon(opts)
  26. },
  27. DisableFlagsInUseLine: true,
  28. Version: fmt.Sprintf("%s, build %s", dockerversion.Version, dockerversion.GitCommit),
  29. }
  30. cli.SetupRootCommand(cmd)
  31. flags := cmd.Flags()
  32. flags.BoolP("version", "v", false, "Print version information and quit")
  33. defaultDaemonConfigFile, err := getDefaultDaemonConfigFile()
  34. if err != nil {
  35. return nil, err
  36. }
  37. flags.StringVar(&opts.configFile, "config-file", defaultDaemonConfigFile, "Daemon configuration file")
  38. opts.InstallFlags(flags)
  39. if err := installConfigFlags(opts.daemonConfig, flags); err != nil {
  40. return nil, err
  41. }
  42. installServiceFlags(flags)
  43. return cmd, nil
  44. }
  45. func init() {
  46. if dockerversion.ProductName != "" {
  47. apicaps.ExportedProduct = dockerversion.ProductName
  48. }
  49. }
  50. func main() {
  51. if reexec.Init() {
  52. return
  53. }
  54. // initial log formatting; this setting is updated after the daemon configuration is loaded.
  55. logrus.SetFormatter(&logrus.TextFormatter{
  56. TimestampFormat: jsonmessage.RFC3339NanoFixed,
  57. FullTimestamp: true,
  58. })
  59. // Set terminal emulation based on platform as required.
  60. _, stdout, stderr := term.StdStreams()
  61. initLogging(stdout, stderr)
  62. onError := func(err error) {
  63. fmt.Fprintf(stderr, "%s\n", err)
  64. os.Exit(1)
  65. }
  66. cmd, err := newDaemonCommand()
  67. if err != nil {
  68. onError(err)
  69. }
  70. cmd.SetOutput(stdout)
  71. if err := cmd.Execute(); err != nil {
  72. onError(err)
  73. }
  74. }