diff options
| author | chrislu <chris.lu@gmail.com> | 2024-03-07 10:42:29 -0800 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2024-03-07 10:42:29 -0800 |
| commit | 8f79bb398780a5b0e746c2be4160e74dcc65b287 (patch) | |
| tree | 34f45830dda7740d125f5f0c33763a1cc019e0af /weed/shell/command_fs_log.go | |
| parent | fe03b1b5228d421f2b9e6903a728aa76866166f1 (diff) | |
| parent | b544a69550d6793dc61eafccc9b850d43bee5d32 (diff) | |
| download | seaweedfs-8f79bb398780a5b0e746c2be4160e74dcc65b287.tar.xz seaweedfs-8f79bb398780a5b0e746c2be4160e74dcc65b287.zip | |
Merge branch 'master' into mq-subscribe
Diffstat (limited to 'weed/shell/command_fs_log.go')
| -rw-r--r-- | weed/shell/command_fs_log.go | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/weed/shell/command_fs_log.go b/weed/shell/command_fs_log.go new file mode 100644 index 000000000..5567f76e6 --- /dev/null +++ b/weed/shell/command_fs_log.go @@ -0,0 +1,53 @@ +package shell + +import ( + "flag" + "fmt" + "github.com/seaweedfs/seaweedfs/weed/filer" + "github.com/seaweedfs/seaweedfs/weed/pb/filer_pb" + "io" + "time" +) + +func init() { + Commands = append(Commands, &commandFsLogPurge{}) +} + +type commandFsLogPurge struct { +} + +func (c *commandFsLogPurge) Name() string { + return "fs.log.purge" +} + +func (c *commandFsLogPurge) Help() string { + return `purge filer logs + + fs.log.purge [-v] [-modifyDayAgo 365] +` +} + +func (c *commandFsLogPurge) Do(args []string, commandEnv *CommandEnv, writer io.Writer) (err error) { + fsLogPurgeCommand := flag.NewFlagSet(c.Name(), flag.ContinueOnError) + daysAgo := fsLogPurgeCommand.Uint("daysAgo", 365, "purge logs older than N days") + verbose := fsLogPurgeCommand.Bool("v", false, "verbose mode") + + if err = fsLogPurgeCommand.Parse(args); err != nil { + return err + } + + modificationTimeAgo := time.Now().Add(-time.Hour * 24 * time.Duration(*daysAgo)).Unix() + err = filer_pb.ReadDirAllEntries(commandEnv, filer.SystemLogDir, "", func(entry *filer_pb.Entry, isLast bool) error { + if entry.Attributes.Mtime > modificationTimeAgo { + return nil + } + if errDel := filer_pb.Remove(commandEnv, filer.SystemLogDir, entry.Name, true, true, true, false, nil); errDel != nil { + return errDel + } + if *verbose { + fmt.Fprintf(writer, "delete %s\n", entry.Name) + } + return nil + }) + return err +} |
