docker.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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/rootless"
  11. "github.com/moby/buildkit/util/apicaps"
  12. "github.com/moby/term"
  13. "github.com/sirupsen/logrus"
  14. "github.com/spf13/cobra"
  15. )
  16. var (
  17. honorXDG bool
  18. )
  19. func newDaemonCommand() (*cobra.Command, error) {
  20. cfg, err := config.New()
  21. if err != nil {
  22. return nil, err
  23. }
  24. opts := newDaemonOptions(cfg)
  25. cmd := &cobra.Command{
  26. Use: "dockerd [OPTIONS]",
  27. Short: "A self-sufficient runtime for containers.",
  28. SilenceUsage: true,
  29. SilenceErrors: true,
  30. Args: cli.NoArgs,
  31. RunE: func(cmd *cobra.Command, args []string) error {
  32. opts.flags = cmd.Flags()
  33. return runDaemon(opts)
  34. },
  35. DisableFlagsInUseLine: true,
  36. Version: fmt.Sprintf("%s, build %s", dockerversion.Version, dockerversion.GitCommit),
  37. }
  38. cli.SetupRootCommand(cmd)
  39. flags := cmd.Flags()
  40. flags.BoolP("version", "v", false, "Print version information and quit")
  41. defaultDaemonConfigFile, err := getDefaultDaemonConfigFile()
  42. if err != nil {
  43. return nil, err
  44. }
  45. flags.StringVar(&opts.configFile, "config-file", defaultDaemonConfigFile, "Daemon configuration file")
  46. configureCertsDir()
  47. opts.installFlags(flags)
  48. if err := installConfigFlags(opts.daemonConfig, flags); err != nil {
  49. return nil, err
  50. }
  51. installServiceFlags(flags)
  52. return cmd, nil
  53. }
  54. func init() {
  55. if dockerversion.ProductName != "" {
  56. apicaps.ExportedProduct = dockerversion.ProductName
  57. }
  58. // When running with RootlessKit, $XDG_RUNTIME_DIR, $XDG_DATA_HOME, and $XDG_CONFIG_HOME needs to be
  59. // honored as the default dirs, because we are unlikely to have permissions to access the system-wide
  60. // directories.
  61. //
  62. // Note that even running with --rootless, when not running with RootlessKit, honorXDG needs to be kept false,
  63. // because the system-wide directories in the current mount namespace are expected to be accessible.
  64. // ("rootful" dockerd in rootless dockerd, #38702)
  65. honorXDG = rootless.RunningWithRootlessKit()
  66. }
  67. func main() {
  68. if reexec.Init() {
  69. return
  70. }
  71. // initial log formatting; this setting is updated after the daemon configuration is loaded.
  72. logrus.SetFormatter(&logrus.TextFormatter{
  73. TimestampFormat: jsonmessage.RFC3339NanoFixed,
  74. FullTimestamp: true,
  75. })
  76. // Set terminal emulation based on platform as required.
  77. _, stdout, stderr := term.StdStreams()
  78. initLogging(stdout, stderr)
  79. onError := func(err error) {
  80. fmt.Fprintf(stderr, "%s\n", err)
  81. os.Exit(1)
  82. }
  83. cmd, err := newDaemonCommand()
  84. if err != nil {
  85. onError(err)
  86. }
  87. cmd.SetOut(stdout)
  88. if err := cmd.Execute(); err != nil {
  89. onError(err)
  90. }
  91. }