Files
kopia/cli/command_maintenance_run.go
Jarek Kowalski d6d9a1fb5f Maintenance improvements for epoch-based index structures (#1225)
* testing: KOPIA_TEST_LOG_OUTPUT logs subcommand outputs

* cli: additional flags for 'blob list'

* Makefile: run all tests against epoch-based index manager

* epoch: added support for deletion watermark, which keeps track of latest maintenance which dropped index entries

* content: added deletion watermark to content manager

* maintenance: improved maintenance without safety to force rewrites

* maintenance: skip quick maintenance when epoch manager is enabled

* maintenance: do not enable quick maintenance when epoch manager is used

* testing: skip TestIndexOptimize when running against epoch manager-backed index strutures
2021-08-02 21:08:54 -07:00

37 lines
1.1 KiB
Go

package cli
import (
"context"
"github.com/kopia/kopia/repo"
"github.com/kopia/kopia/repo/maintenance"
"github.com/kopia/kopia/snapshot/snapshotmaintenance"
)
type commandMaintenanceRun struct {
maintenanceRunFull bool
maintenanceRunForce bool
safety maintenance.SafetyParameters
}
func (c *commandMaintenanceRun) setup(svc appServices, parent commandParent) {
cmd := parent.Command("run", "Run repository maintenance").Default()
cmd.Flag("full", "Full maintenance").BoolVar(&c.maintenanceRunFull)
cmd.Flag("force", "Run maintenance even if not owned (unsafe)").Hidden().BoolVar(&c.maintenanceRunForce)
safetyFlagVar(cmd, &c.safety)
cmd.Action(svc.directRepositoryWriteAction(c.run))
}
func (c *commandMaintenanceRun) run(ctx context.Context, rep repo.DirectRepositoryWriter) error {
mode := maintenance.ModeQuick
_, supportsEpochManager := rep.ContentManager().EpochManager()
if c.maintenanceRunFull || supportsEpochManager {
mode = maintenance.ModeFull
}
// nolint:wrapcheck
return snapshotmaintenance.Run(ctx, rep, mode, c.maintenanceRunForce, c.safety)
}