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.

90 lines
2.9 KiB

11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
11 years ago
  1. package main
  2. import (
  3. "net/http"
  4. "os"
  5. "strconv"
  6. "time"
  7. "github.com/chrislusf/weed-fs/go/glog"
  8. "github.com/chrislusf/weed-fs/go/util"
  9. "github.com/chrislusf/weed-fs/go/weed/weed_server"
  10. )
  11. var (
  12. f FilerOptions
  13. )
  14. type FilerOptions struct {
  15. master *string
  16. port *int
  17. collection *string
  18. defaultReplicaPlacement *string
  19. dir *string
  20. redirectOnRead *bool
  21. cassandra_server *string
  22. cassandra_keyspace *string
  23. }
  24. func init() {
  25. cmdFiler.Run = runFiler // break init cycle
  26. f.master = cmdFiler.Flag.String("master", "localhost:9333", "master server location")
  27. f.collection = cmdFiler.Flag.String("collection", "", "all data will be stored in this collection")
  28. f.port = cmdFiler.Flag.Int("port", 8888, "filer server http listen port")
  29. f.dir = cmdFiler.Flag.String("dir", os.TempDir(), "directory to store meta data")
  30. f.defaultReplicaPlacement = cmdFiler.Flag.String("defaultReplicaPlacement", "000", "default replication type if not specified")
  31. f.redirectOnRead = cmdFiler.Flag.Bool("redirectOnRead", false, "whether proxy or redirect to volume server during file GET request")
  32. f.cassandra_server = cmdFiler.Flag.String("cassandra.server", "", "host[:port] of the cassandra server")
  33. f.cassandra_keyspace = cmdFiler.Flag.String("cassandra.keyspace", "seaweed", "keyspace of the cassandra server")
  34. }
  35. var cmdFiler = &Command{
  36. UsageLine: "filer -port=8888 -dir=/tmp -master=<ip:port>",
  37. Short: "start a file server that points to a master server",
  38. Long: `start a file server which accepts REST operation for any files.
  39. //create or overwrite the file, the directories /path/to will be automatically created
  40. POST /path/to/file
  41. //get the file content
  42. GET /path/to/file
  43. //create or overwrite the file, the filename in the multipart request will be used
  44. POST /path/to/
  45. //return a json format subdirectory and files listing
  46. GET /path/to/
  47. Current <fullpath~fileid> mapping metadata store is local embedded leveldb.
  48. It should be highly scalable to hundreds of millions of files on a modest machine.
  49. Future we will ensure it can avoid of being SPOF.
  50. `,
  51. }
  52. func runFiler(cmd *Command, args []string) bool {
  53. if err := util.TestFolderWritable(*f.dir); err != nil {
  54. glog.Fatalf("Check Meta Folder (-dir) Writable %s : %s", *f.dir, err)
  55. }
  56. r := http.NewServeMux()
  57. _, nfs_err := weed_server.NewFilerServer(r, *f.port, *f.master, *f.dir, *f.collection,
  58. *f.defaultReplicaPlacement, *f.redirectOnRead,
  59. *f.cassandra_server, *f.cassandra_keyspace,
  60. )
  61. if nfs_err != nil {
  62. glog.Fatalf(nfs_err.Error())
  63. }
  64. glog.V(0).Infoln("Start Seaweed Filer", util.VERSION, "at port", strconv.Itoa(*f.port))
  65. filerListener, e := util.NewListener(
  66. ":"+strconv.Itoa(*f.port),
  67. time.Duration(10)*time.Second,
  68. )
  69. if e != nil {
  70. glog.Fatalf(e.Error())
  71. }
  72. if e := http.Serve(filerListener, r); e != nil {
  73. glog.Fatalf("Filer Fail to serve:%s", e.Error())
  74. }
  75. return true
  76. }