You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

70 lines
2.5 KiB

13 years ago
13 years ago
13 years ago
13 years ago
13 years ago
13 years ago
  1. package main
  2. import (
  3. "code.google.com/p/weed-fs/go/glog"
  4. "code.google.com/p/weed-fs/go/weed/weed_server"
  5. "github.com/gorilla/mux"
  6. "net/http"
  7. "os"
  8. "runtime"
  9. "strconv"
  10. "strings"
  11. "time"
  12. )
  13. func init() {
  14. cmdMaster.Run = runMaster // break init cycle
  15. }
  16. var cmdMaster = &Command{
  17. UsageLine: "master -port=9333",
  18. Short: "start a master server",
  19. Long: `start a master server to provide volume=>location mapping service
  20. and sequence number of file ids
  21. `,
  22. }
  23. var (
  24. mport = cmdMaster.Flag.Int("port", 9333, "http listen port")
  25. mip = cmdMaster.Flag.String("ip", "localhost", "http listen port")
  26. metaFolder = cmdMaster.Flag.String("mdir", os.TempDir(), "data directory to store mappings")
  27. volumeSizeLimitMB = cmdMaster.Flag.Uint("volumeSizeLimitMB", 32*1024, "Default Volume Size in MegaBytes")
  28. mpulse = cmdMaster.Flag.Int("pulseSeconds", 5, "number of seconds between heartbeats")
  29. confFile = cmdMaster.Flag.String("conf", "/etc/weedfs/weedfs.conf", "xml configuration file")
  30. defaultRepType = cmdMaster.Flag.String("defaultReplicationType", "000", "Default replication type if not specified.")
  31. mReadTimeout = cmdMaster.Flag.Int("readTimeout", 3, "connection read timeout in seconds")
  32. mMaxCpu = cmdMaster.Flag.Int("maxCpu", 0, "maximum number of CPUs. 0 means all available CPUs")
  33. garbageThreshold = cmdMaster.Flag.String("garbageThreshold", "0.3", "threshold to vacuum and reclaim spaces")
  34. masterWhiteListOption = cmdMaster.Flag.String("whiteList", "", "comma separated Ip addresses having write permission. No limit if empty.")
  35. //etcdCluster = cmdMaster.Flag.String("etcd", "", "comma separated etcd urls, e.g., http://localhost:4001, See github.com/coreos/go-etcd/etcd")
  36. masterWhiteList []string
  37. )
  38. func runMaster(cmd *Command, args []string) bool {
  39. if *mMaxCpu < 1 {
  40. *mMaxCpu = runtime.NumCPU()
  41. }
  42. runtime.GOMAXPROCS(*mMaxCpu)
  43. if *masterWhiteListOption != "" {
  44. masterWhiteList = strings.Split(*masterWhiteListOption, ",")
  45. }
  46. r := mux.NewRouter()
  47. weed_server.NewMasterServer(r, VERSION, *mport, *metaFolder,
  48. *volumeSizeLimitMB, *mpulse, *confFile, *defaultRepType, *garbageThreshold, masterWhiteList,
  49. )
  50. glog.V(0).Infoln("Start Weed Master", VERSION, "at port", *mip+":"+strconv.Itoa(*mport))
  51. srv := &http.Server{
  52. Addr: *mip+":" + strconv.Itoa(*mport),
  53. Handler: r,
  54. ReadTimeout: time.Duration(*mReadTimeout) * time.Second,
  55. }
  56. e := srv.ListenAndServe()
  57. if e != nil {
  58. glog.Fatalf("Fail to start:%s", e)
  59. }
  60. return true
  61. }