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.

101 lines
2.9 KiB

7 years ago
7 years ago
7 years ago
  1. package weed_server
  2. import (
  3. "fmt"
  4. "net/http"
  5. "path/filepath"
  6. "strconv"
  7. "github.com/chrislusf/seaweedfs/weed/glog"
  8. "github.com/chrislusf/seaweedfs/weed/stats"
  9. "github.com/chrislusf/seaweedfs/weed/storage"
  10. "github.com/chrislusf/seaweedfs/weed/util"
  11. )
  12. func (vs *VolumeServer) statusHandler(w http.ResponseWriter, r *http.Request) {
  13. m := make(map[string]interface{})
  14. m["Version"] = util.VERSION
  15. m["Volumes"] = vs.store.Status()
  16. writeJsonQuiet(w, r, http.StatusOK, m)
  17. }
  18. func (vs *VolumeServer) assignVolumeHandler(w http.ResponseWriter, r *http.Request) {
  19. var err error
  20. preallocate := int64(0)
  21. if r.FormValue("preallocate") != "" {
  22. preallocate, err = strconv.ParseInt(r.FormValue("preallocate"), 10, 64)
  23. if err != nil {
  24. glog.V(0).Infof("ignoring invalid int64 value for preallocate = %v", r.FormValue("preallocate"))
  25. }
  26. }
  27. err = vs.store.AddVolume(
  28. r.FormValue("volume"),
  29. r.FormValue("collection"),
  30. vs.needleMapKind,
  31. r.FormValue("replication"),
  32. r.FormValue("ttl"),
  33. preallocate,
  34. )
  35. if err == nil {
  36. writeJsonQuiet(w, r, http.StatusAccepted, map[string]string{"error": ""})
  37. } else {
  38. writeJsonError(w, r, http.StatusNotAcceptable, err)
  39. }
  40. glog.V(2).Infof("assign volume = %s, collection = %s , replication = %s, error = %v",
  41. r.FormValue("volume"), r.FormValue("collection"), r.FormValue("replication"), err)
  42. }
  43. func (vs *VolumeServer) statsDiskHandler(w http.ResponseWriter, r *http.Request) {
  44. m := make(map[string]interface{})
  45. m["Version"] = util.VERSION
  46. var ds []*stats.DiskStatus
  47. for _, loc := range vs.store.Locations {
  48. if dir, e := filepath.Abs(loc.Directory); e == nil {
  49. ds = append(ds, stats.NewDiskStatus(dir))
  50. }
  51. }
  52. m["DiskStatuses"] = ds
  53. writeJsonQuiet(w, r, http.StatusOK, m)
  54. }
  55. func (vs *VolumeServer) getVolume(volumeParameterName string, r *http.Request) (*storage.Volume, error) {
  56. vid, err := vs.getVolumeId(volumeParameterName, r)
  57. if err != nil {
  58. return nil, err
  59. }
  60. v := vs.store.GetVolume(vid)
  61. if v == nil {
  62. return nil, fmt.Errorf("Not Found Volume Id %d", vid)
  63. }
  64. return v, nil
  65. }
  66. func (vs *VolumeServer) getVolumeMountHandler(w http.ResponseWriter, r *http.Request) {
  67. vid, err := vs.getVolumeId("volume", r)
  68. if err != nil {
  69. writeJsonError(w, r, http.StatusNotFound, err)
  70. return
  71. }
  72. vs.store.MountVolume(vid)
  73. writeJsonQuiet(w, r, http.StatusOK, "Volume mounted")
  74. }
  75. func (vs *VolumeServer) getVolumeUnmountHandler(w http.ResponseWriter, r *http.Request) {
  76. vid, err := vs.getVolumeId("volume", r)
  77. if err != nil {
  78. writeJsonError(w, r, http.StatusNotFound, err)
  79. return
  80. }
  81. vs.store.UnmountVolume(vid)
  82. writeJsonQuiet(w, r, http.StatusOK, "Volume unmounted")
  83. }
  84. func (vs *VolumeServer) getVolumeDeleteHandler(w http.ResponseWriter, r *http.Request) {
  85. vid, err := vs.getVolumeId("volume", r)
  86. if err != nil {
  87. writeJsonError(w, r, http.StatusNotFound, err)
  88. return
  89. }
  90. vs.store.DeleteVolume(vid)
  91. writeJsonQuiet(w, r, http.StatusOK, "Volume deleted")
  92. }