seaweedfs/weed/shell/command_volume_vacuum.go

62 lines
1.5 KiB
Go
Raw Normal View History

2020-11-29 15:18:02 +08:00
package shell
import (
"context"
"flag"
"io"
"github.com/seaweedfs/seaweedfs/weed/pb/master_pb"
2020-11-29 15:18:02 +08:00
)
func init() {
Commands = append(Commands, &commandVacuum{})
}
type commandVacuum struct {
}
func (c *commandVacuum) Name() string {
return "volume.vacuum"
}
func (c *commandVacuum) Help() string {
return `compact volumes if deleted entries are more than the limit
2022-04-18 22:36:14 +08:00
volume.vacuum [-garbageThreshold=0.3] [-collection=<collection name>] [-volumeId=<volume id>]
2020-11-29 15:18:02 +08:00
`
}
2024-09-30 01:38:22 +08:00
func (c *commandVacuum) HasTag(CommandTag) bool {
return false
}
2020-11-29 15:18:02 +08:00
func (c *commandVacuum) Do(args []string, commandEnv *CommandEnv, writer io.Writer) (err error) {
volumeVacuumCommand := flag.NewFlagSet(c.Name(), flag.ContinueOnError)
garbageThreshold := volumeVacuumCommand.Float64("garbageThreshold", 0.3, "vacuum when garbage is more than this limit")
collection := volumeVacuumCommand.String("collection", "", "vacuum this collection")
2022-04-18 22:36:14 +08:00
volumeId := volumeVacuumCommand.Uint("volumeId", 0, "the volume id")
2020-11-29 15:18:02 +08:00
if err = volumeVacuumCommand.Parse(args); err != nil {
2022-04-29 11:19:36 +08:00
return nil
2020-11-29 15:18:02 +08:00
}
2021-12-11 05:24:38 +08:00
if err = commandEnv.confirmIsLocked(args); err != nil {
return
}
err = commandEnv.MasterClient.WithClient(false, func(client master_pb.SeaweedClient) error {
2020-11-29 15:18:02 +08:00
_, err = client.VacuumVolume(context.Background(), &master_pb.VacuumVolumeRequest{
GarbageThreshold: float32(*garbageThreshold),
VolumeId: uint32(*volumeId),
Collection: *collection,
2020-11-29 15:18:02 +08:00
})
return err
})
if err != nil {
return
}
return nil
}