mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
configure mount quota
This commit is contained in:
parent
958f880b70
commit
6a2bcd03aa
|
@ -64,7 +64,7 @@ func init() {
|
||||||
mountOptions.readOnly = cmdMount.Flag.Bool("readOnly", false, "read only")
|
mountOptions.readOnly = cmdMount.Flag.Bool("readOnly", false, "read only")
|
||||||
mountOptions.debug = cmdMount.Flag.Bool("debug", false, "serves runtime profiling data, e.g., http://localhost:<debug.port>/debug/pprof/goroutine?debug=2")
|
mountOptions.debug = cmdMount.Flag.Bool("debug", false, "serves runtime profiling data, e.g., http://localhost:<debug.port>/debug/pprof/goroutine?debug=2")
|
||||||
mountOptions.debugPort = cmdMount.Flag.Int("debug.port", 6061, "http port for debugging")
|
mountOptions.debugPort = cmdMount.Flag.Int("debug.port", 6061, "http port for debugging")
|
||||||
mountOptions.localSocket = cmdFiler.Flag.String("localSocket", "", "default to /tmp/seaweedfs-mount-<mount_dir_hash>.sock")
|
mountOptions.localSocket = cmdMount.Flag.String("localSocket", "", "default to /tmp/seaweedfs-mount-<mount_dir_hash>.sock")
|
||||||
|
|
||||||
mountCpuProfile = cmdMount.Flag.String("cpuprofile", "", "cpu profile output file")
|
mountCpuProfile = cmdMount.Flag.String("cpuprofile", "", "cpu profile output file")
|
||||||
mountMemProfile = cmdMount.Flag.String("memprofile", "", "memory profile output file")
|
mountMemProfile = cmdMount.Flag.String("memprofile", "", "memory profile output file")
|
||||||
|
|
|
@ -2,11 +2,15 @@ package mount
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"fmt"
|
||||||
"github.com/chrislusf/seaweedfs/weed/glog"
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
||||||
"github.com/chrislusf/seaweedfs/weed/pb/mount_pb"
|
"github.com/chrislusf/seaweedfs/weed/pb/mount_pb"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (wfs *WFS) Configure(ctx context.Context, request *mount_pb.ConfigureRequest) (*mount_pb.ConfigureResponse, error) {
|
func (wfs *WFS) Configure(ctx context.Context, request *mount_pb.ConfigureRequest) (*mount_pb.ConfigureResponse, error) {
|
||||||
|
if wfs.option.Collection == "" {
|
||||||
|
return nil, fmt.Errorf("mount quota only works when mounted to a new folder with a collection")
|
||||||
|
}
|
||||||
glog.V(0).Infof("quota changed from %d to %d", wfs.option.Quota, request.CollectionCapacity)
|
glog.V(0).Infof("quota changed from %d to %d", wfs.option.Quota, request.CollectionCapacity)
|
||||||
wfs.option.Quota = request.GetCollectionCapacity()
|
wfs.option.Quota = request.GetCollectionCapacity()
|
||||||
return &mount_pb.ConfigureResponse{}, nil
|
return &mount_pb.ConfigureResponse{}, nil
|
||||||
|
|
64
weed/shell/command_mount_configure.go
Normal file
64
weed/shell/command_mount_configure.go
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
package shell
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"flag"
|
||||||
|
"fmt"
|
||||||
|
"github.com/chrislusf/seaweedfs/weed/pb/mount_pb"
|
||||||
|
"github.com/chrislusf/seaweedfs/weed/util"
|
||||||
|
"google.golang.org/grpc"
|
||||||
|
"google.golang.org/grpc/credentials/insecure"
|
||||||
|
_ "google.golang.org/grpc/resolver/passthrough"
|
||||||
|
"io"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
Commands = append(Commands, &commandMountConfigure{})
|
||||||
|
}
|
||||||
|
|
||||||
|
type commandMountConfigure struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *commandMountConfigure) Name() string {
|
||||||
|
return "mount.configure"
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *commandMountConfigure) Help() string {
|
||||||
|
return `configure the mount on current server
|
||||||
|
|
||||||
|
mount.configure -dir=<mount_directory>
|
||||||
|
|
||||||
|
This command connects with local mount via unix socket, so it can only run locally.
|
||||||
|
The "mount_directory" value needs to be exactly the same as how mount was started in "weed mount -dir=<mount_directory>"
|
||||||
|
|
||||||
|
`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *commandMountConfigure) Do(args []string, commandEnv *CommandEnv, writer io.Writer) (err error) {
|
||||||
|
|
||||||
|
mountConfigureCommand := flag.NewFlagSet(c.Name(), flag.ContinueOnError)
|
||||||
|
mountDir := mountConfigureCommand.String("dir", "", "the mount directory same as how \"weed mount -dir=<mount_directory>\" was started")
|
||||||
|
mountQuota := mountConfigureCommand.Int("quotaMB", 0, "the quota in MB")
|
||||||
|
if err = mountConfigureCommand.Parse(args); err != nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
mountDirHash := util.HashToInt32([]byte(*mountDir))
|
||||||
|
if mountDirHash < 0 {
|
||||||
|
mountDirHash = -mountDirHash
|
||||||
|
}
|
||||||
|
localSocket := fmt.Sprintf("/tmp/seaweefs-mount-%d.sock", mountDirHash)
|
||||||
|
|
||||||
|
clientConn, err := grpc.Dial("passthrough:///unix://"+localSocket, grpc.WithTransportCredentials(insecure.NewCredentials()))
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
defer clientConn.Close()
|
||||||
|
|
||||||
|
client := mount_pb.NewSeaweedMountClient(clientConn)
|
||||||
|
_, err = client.Configure(context.Background(), &mount_pb.ConfigureRequest{
|
||||||
|
CollectionCapacity: int64(*mountQuota) * 1024 * 1024,
|
||||||
|
})
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
Loading…
Reference in a new issue