Files
kopia/cli/command_blob_stats.go
Jarek Kowalski e03971fc59 Upgraded linter to v1.33.0 (#734)
* linter: upgraded to 1.33, disabled some linters

* lint: fixed 'errorlint' errors

This ensures that all error comparisons use errors.Is() or errors.As().
We will be wrapping more errors going forward so it's important that
error checks are not strict everywhere.

Verified that there are no exceptions for errorlint linter which
guarantees that.

* lint: fixed or suppressed wrapcheck errors

* lint: nolintlint and misc cleanups

Co-authored-by: Julio López <julio+gh@kasten.io>
2020-12-21 22:39:22 -08:00

92 lines
1.9 KiB
Go

package cli
import (
"context"
"fmt"
"strconv"
"github.com/pkg/errors"
"github.com/kopia/kopia/internal/units"
"github.com/kopia/kopia/repo"
"github.com/kopia/kopia/repo/blob"
)
var (
blobStatsCommand = blobCommands.Command("stats", "Content statistics")
blobStatsRaw = blobStatsCommand.Flag("raw", "Raw numbers").Short('r').Bool()
blobStatsPrefix = blobStatsCommand.Flag("prefix", "Blob name prefix").String()
)
func runBlobStatsCommand(ctx context.Context, rep *repo.DirectRepository) error {
var sizeThreshold int64 = 10
countMap := map[int64]int{}
totalSizeOfContentsUnder := map[int64]int64{}
var sizeThresholds []int64
for i := 0; i < 8; i++ {
sizeThresholds = append(sizeThresholds, sizeThreshold)
countMap[sizeThreshold] = 0
sizeThreshold *= 10
}
var totalSize, count int64
if err := rep.Blobs.ListBlobs(
ctx,
blob.ID(*blobStatsPrefix),
func(b blob.Metadata) error {
totalSize += b.Length
count++
if count%10000 == 0 {
log(ctx).Infof("Got %v blobs...", count)
}
for s := range countMap {
if b.Length < s {
countMap[s]++
totalSizeOfContentsUnder[s] += b.Length
}
}
return nil
}); err != nil {
return errors.Wrap(err, "error listing blobs")
}
sizeToString := units.BytesStringBase10
if *blobStatsRaw {
sizeToString = func(l int64) string { return strconv.FormatInt(l, 10) }
}
fmt.Println("Count:", count)
fmt.Println("Total:", sizeToString(totalSize))
if count == 0 {
return nil
}
fmt.Println("Average:", sizeToString(totalSize/count))
fmt.Printf("Histogram:\n\n")
var lastSize int64
for _, size := range sizeThresholds {
fmt.Printf("%9v between %v and %v (total %v)\n",
countMap[size]-countMap[lastSize],
sizeToString(lastSize),
sizeToString(size),
sizeToString(totalSizeOfContentsUnder[size]-totalSizeOfContentsUnder[lastSize]),
)
lastSize = size
}
return nil
}
func init() {
blobStatsCommand.Action(directRepositoryAction(runBlobStatsCommand))
}