daemon.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. // +build daemon
  2. package main
  3. import (
  4. "log"
  5. "github.com/docker/docker/builtins"
  6. "github.com/docker/docker/daemon"
  7. _ "github.com/docker/docker/daemon/execdriver/lxc"
  8. _ "github.com/docker/docker/daemon/execdriver/native"
  9. "github.com/docker/docker/dockerversion"
  10. "github.com/docker/docker/engine"
  11. flag "github.com/docker/docker/pkg/mflag"
  12. "github.com/docker/docker/pkg/signal"
  13. )
  14. const CanDaemon = true
  15. var (
  16. daemonCfg = &daemon.Config{}
  17. )
  18. func init() {
  19. daemonCfg.InstallFlags()
  20. }
  21. func mainDaemon() {
  22. if flag.NArg() != 0 {
  23. flag.Usage()
  24. return
  25. }
  26. eng := engine.New()
  27. signal.Trap(eng.Shutdown)
  28. // Load builtins
  29. if err := builtins.Register(eng); err != nil {
  30. log.Fatal(err)
  31. }
  32. // load the daemon in the background so we can immediately start
  33. // the http api so that connections don't fail while the daemon
  34. // is booting
  35. go func() {
  36. d, err := daemon.NewDaemon(daemonCfg, eng)
  37. if err != nil {
  38. log.Fatal(err)
  39. }
  40. if err := d.Install(eng); err != nil {
  41. log.Fatal(err)
  42. }
  43. // after the daemon is done setting up we can tell the api to start
  44. // accepting connections
  45. if err := eng.Job("acceptconnections").Run(); err != nil {
  46. log.Fatal(err)
  47. }
  48. }()
  49. // TODO actually have a resolved graphdriver to show?
  50. log.Printf("docker daemon: %s %s; execdriver: %s; graphdriver: %s",
  51. dockerversion.VERSION,
  52. dockerversion.GITCOMMIT,
  53. daemonCfg.ExecDriver,
  54. daemonCfg.GraphDriver,
  55. )
  56. // Serve api
  57. job := eng.Job("serveapi", flHosts...)
  58. job.SetenvBool("Logging", true)
  59. job.SetenvBool("EnableCors", *flEnableCors)
  60. job.Setenv("Version", dockerversion.VERSION)
  61. job.Setenv("SocketGroup", *flSocketGroup)
  62. job.SetenvBool("Tls", *flTls)
  63. job.SetenvBool("TlsVerify", *flTlsVerify)
  64. job.Setenv("TlsCa", *flCa)
  65. job.Setenv("TlsCert", *flCert)
  66. job.Setenv("TlsKey", *flKey)
  67. job.SetenvBool("BufferRequests", true)
  68. if err := job.Run(); err != nil {
  69. log.Fatal(err)
  70. }
  71. }