docker.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "github.com/dotcloud/docker"
  6. "io/ioutil"
  7. "log"
  8. "os"
  9. "os/signal"
  10. "strconv"
  11. "syscall"
  12. )
  13. var (
  14. GIT_COMMIT string
  15. )
  16. func main() {
  17. if docker.SelfPath() == "/sbin/init" {
  18. // Running in init mode
  19. docker.SysInit()
  20. return
  21. }
  22. // FIXME: Switch d and D ? (to be more sshd like)
  23. flDaemon := flag.Bool("d", false, "Daemon mode")
  24. flDebug := flag.Bool("D", false, "Debug mode")
  25. flAutoRestart := flag.Bool("r", false, "Restart previously running containers")
  26. bridgeName := flag.String("b", "", "Attach containers to a pre-existing network bridge")
  27. pidfile := flag.String("p", "/var/run/docker.pid", "File containing process PID")
  28. flag.Parse()
  29. if *bridgeName != "" {
  30. docker.NetworkBridgeIface = *bridgeName
  31. } else {
  32. docker.NetworkBridgeIface = docker.DefaultNetworkBridge
  33. }
  34. if *flDebug {
  35. os.Setenv("DEBUG", "1")
  36. }
  37. docker.GIT_COMMIT = GIT_COMMIT
  38. if *flDaemon {
  39. if flag.NArg() != 0 {
  40. flag.Usage()
  41. return
  42. }
  43. if err := daemon(*pidfile, *flAutoRestart); err != nil {
  44. log.Fatal(err)
  45. os.Exit(-1)
  46. }
  47. } else {
  48. if err := docker.ParseCommands(flag.Args()...); err != nil {
  49. log.Fatal(err)
  50. os.Exit(-1)
  51. }
  52. }
  53. }
  54. func createPidFile(pidfile string) error {
  55. if pidString, err := ioutil.ReadFile(pidfile); err == nil {
  56. pid, err := strconv.Atoi(string(pidString))
  57. if err == nil {
  58. if _, err := os.Stat(fmt.Sprintf("/proc/%d/", pid)); err == nil {
  59. return fmt.Errorf("pid file found, ensure docker is not running or delete %s", pidfile)
  60. }
  61. }
  62. }
  63. file, err := os.Create(pidfile)
  64. if err != nil {
  65. return err
  66. }
  67. defer file.Close()
  68. _, err = fmt.Fprintf(file, "%d", os.Getpid())
  69. return err
  70. }
  71. func removePidFile(pidfile string) {
  72. if err := os.Remove(pidfile); err != nil {
  73. log.Printf("Error removing %s: %s", pidfile, err)
  74. }
  75. }
  76. func daemon(pidfile string, autoRestart bool) error {
  77. if err := createPidFile(pidfile); err != nil {
  78. log.Fatal(err)
  79. }
  80. defer removePidFile(pidfile)
  81. c := make(chan os.Signal, 1)
  82. signal.Notify(c, os.Interrupt, os.Kill, os.Signal(syscall.SIGTERM))
  83. go func() {
  84. sig := <-c
  85. log.Printf("Received signal '%v', exiting\n", sig)
  86. removePidFile(pidfile)
  87. os.Exit(0)
  88. }()
  89. server, err := docker.NewServer(autoRestart)
  90. if err != nil {
  91. return err
  92. }
  93. return docker.ListenAndServe("0.0.0.0:4243", server)
  94. }