Files
kopia/cli/command_index_epoch_list.go
Jarek Kowalski 62ad437bb6 Implemented epoch-based index manager (#1174)
* epoch: misc fixes and logging

* blob: misc helpers

* cli: removed useless 'repository upgrade', replaced by 'repository set-parameters'

* content: implemented indexBlobManagerV1 which uses epoch manager

* cli: commands to manipulate repository epoch parameters

* cli: commands to examine epoch-based indexes

* content: added test suite that uses epoch-based index manager

* content: fixed a ton of test data races caused by sharing blobtesting.DataMap

* cli: additional tests and validation for 'repository set-params'

* testing: replaced the use of suite with our own, since suite is not parallelizable
2021-07-06 21:38:08 -07:00

83 lines
2.0 KiB
Go

package cli
import (
"context"
"time"
"github.com/pkg/errors"
"github.com/kopia/kopia/internal/units"
"github.com/kopia/kopia/repo"
"github.com/kopia/kopia/repo/blob"
)
type commandIndexEpochList struct {
out textOutput
}
func (c *commandIndexEpochList) setup(svc appServices, parent commandParent) {
cmd := parent.Command("list", "List the status of epochs.")
cmd.Action(svc.directRepositoryReadAction(c.run))
c.out.setup(svc)
}
func (c *commandIndexEpochList) run(ctx context.Context, rep repo.DirectRepository) error {
emgr, ok := rep.ContentReader().EpochManager()
if !ok {
return errors.Errorf("epoch manager is not active")
}
snap, err := emgr.Current(ctx)
if err != nil {
return errors.Wrap(err, "unable to determine current epoch")
}
c.out.printStdout("Current Epoch: %v\n", snap.WriteEpoch)
if est := snap.EpochStartTime[snap.WriteEpoch]; !est.IsZero() {
c.out.printStdout("Epoch Started %v\n", formatTimestamp(est))
}
firstNonRangeCompacted := 0
if len(snap.LongestRangeCheckpointSets) > 0 {
firstNonRangeCompacted = snap.LongestRangeCheckpointSets[len(snap.LongestRangeCheckpointSets)-1].MaxEpoch + 1
}
for e := snap.WriteEpoch; e >= firstNonRangeCompacted; e-- {
if uces := snap.UncompactedEpochSets[e]; len(uces) > 0 {
min := blob.MinTimestamp(uces)
max := blob.MaxTimestamp(uces)
c.out.printStdout("%v %v ... %v, %v blobs, %v, span %v\n",
e,
formatTimestamp(min),
formatTimestamp(max),
len(uces),
units.BytesStringBase2(blob.TotalLength(uces)),
max.Sub(min).Round(time.Second),
)
}
if secs := snap.SingleEpochCompactionSets[e]; secs != nil {
c.out.printStdout("%v: %v single-epoch %v blobs, %v\n",
e,
formatTimestamp(secs[0].Timestamp),
len(secs),
units.BytesStringBase2(blob.TotalLength(secs)),
)
}
}
for _, cs := range snap.LongestRangeCheckpointSets {
c.out.printStdout("%v-%v: range, %v blobs, %v\n",
cs.MinEpoch,
cs.MaxEpoch,
len(cs.Blobs),
units.BytesStringBase2(blob.TotalLength(cs.Blobs)),
)
}
return nil
}