|
@ -2,7 +2,6 @@ package weed_server |
|
|
|
|
|
|
|
|
import ( |
|
|
import ( |
|
|
"context" |
|
|
"context" |
|
|
"errors" |
|
|
|
|
|
"fmt" |
|
|
"fmt" |
|
|
"math/rand" |
|
|
"math/rand" |
|
|
"net/http" |
|
|
"net/http" |
|
@ -68,7 +67,7 @@ func (ms *MasterServer) volumeGrowHandler(w http.ResponseWriter, r *http.Request |
|
|
writeJsonError(w, r, http.StatusNotAcceptable, err) |
|
|
writeJsonError(w, r, http.StatusNotAcceptable, err) |
|
|
return |
|
|
return |
|
|
} |
|
|
} |
|
|
if err == nil { |
|
|
|
|
|
|
|
|
|
|
|
if count, err = strconv.Atoi(r.FormValue("count")); err == nil { |
|
|
if count, err = strconv.Atoi(r.FormValue("count")); err == nil { |
|
|
if ms.Topo.FreeSpace() < int64(count*option.ReplicaPlacement.GetCopyCount()) { |
|
|
if ms.Topo.FreeSpace() < int64(count*option.ReplicaPlacement.GetCopyCount()) { |
|
|
err = fmt.Errorf("only %d volumes left, not enough for %d", ms.Topo.FreeSpace(), count*option.ReplicaPlacement.GetCopyCount()) |
|
|
err = fmt.Errorf("only %d volumes left, not enough for %d", ms.Topo.FreeSpace(), count*option.ReplicaPlacement.GetCopyCount()) |
|
@ -76,9 +75,9 @@ func (ms *MasterServer) volumeGrowHandler(w http.ResponseWriter, r *http.Request |
|
|
count, err = ms.vg.GrowByCountAndType(ms.grpcDialOpiton, count, option, ms.Topo) |
|
|
count, err = ms.vg.GrowByCountAndType(ms.grpcDialOpiton, count, option, ms.Topo) |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
err = errors.New("parameter count is not found") |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
err = fmt.Errorf("can not parse parameter count %s", r.FormValue("count")) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if err != nil { |
|
|
if err != nil { |
|
|
writeJsonError(w, r, http.StatusNotAcceptable, err) |
|
|
writeJsonError(w, r, http.StatusNotAcceptable, err) |
|
|
} else { |
|
|
} else { |
|
|