daemon.go 2.2 KB

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