rollup

package
v0.12.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 28, 2019 License: AGPL-3.0 Imports: 9 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var (
	Error = errs.Class("rollup error")
)

Error is a standard error class for this package.

Functions

This section is empty.

Types

type Config

type Config struct {
	Interval      time.Duration `help:"how frequently rollup should run" releaseDefault:"24h" devDefault:"120s"`
	MaxAlphaUsage memory.Size   `help:"the bandwidth and storage usage limit for the alpha release" default:"25GB"`
	DeleteTallies bool          `help:"option for deleting tallies after they are rolled up" default:"false"`
}

Config contains configurable values for rollup

type Service added in v0.9.0

type Service struct {
	// contains filtered or unexported fields
}

Service is the rollup service for totalling data on storage nodes on daily intervals

func New

func New(logger *zap.Logger, sdb accounting.StoragenodeAccounting, interval time.Duration, deleteTallies bool) *Service

New creates a new rollup service

func (*Service) Rollup added in v0.9.0

func (r *Service) Rollup(ctx context.Context) error

Rollup aggregates storage and bandwidth amounts for the time interval

func (*Service) RollupBW added in v0.9.0

func (r *Service) RollupBW(ctx context.Context, lastRollup time.Time, rollupStats accounting.RollupStats) error

RollupBW aggregates the bandwidth rollups, modifies rollupStats map

func (*Service) RollupStorage added in v0.9.0

func (r *Service) RollupStorage(ctx context.Context, lastRollup time.Time, rollupStats accounting.RollupStats) (latestTally time.Time, err error)

RollupStorage rolls up storage tally, modifies rollupStats map

func (*Service) Run added in v0.9.0

func (r *Service) Run(ctx context.Context) (err error)

Run the Rollup loop

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL