accounting: fix stats to show server side transfers

Before this fix we were not counting transferred files nor transferred
bytes for server side moves/copies.

If the server side move/copy has been marked as a transfer and not a
checker then this accounts transferred files and transferred bytes.

The transferred bytes are not accounted to the network though so this
should not affect the network stats.
This commit is contained in:
Nick Craig-Wood 2024-01-04 11:39:51 +00:00
parent 771ec943f2
commit ad8bde69b3
3 changed files with 30 additions and 11 deletions

View File

@ -49,17 +49,18 @@ type Account struct {
// in http transport calls Read() after Do() returns on // in http transport calls Read() after Do() returns on
// CancelRequest so this race can happen when it apparently // CancelRequest so this race can happen when it apparently
// shouldn't. // shouldn't.
mu sync.Mutex // mutex protects these values mu sync.Mutex // mutex protects these values
in io.Reader in io.Reader
ctx context.Context // current context for transfer - may change ctx context.Context // current context for transfer - may change
ci *fs.ConfigInfo ci *fs.ConfigInfo
origIn io.ReadCloser origIn io.ReadCloser
close io.Closer close io.Closer
size int64 size int64
name string name string
closed bool // set if the file is closed closed bool // set if the file is closed
exit chan struct{} // channel that will be closed when transfer is finished exit chan struct{} // channel that will be closed when transfer is finished
withBuf bool // is using a buffered in withBuf bool // is using a buffered in
checking bool // set if attached transfer is checking
tokenBucket buckets // per file bandwidth limiter (may be nil) tokenBucket buckets // per file bandwidth limiter (may be nil)
@ -295,14 +296,24 @@ func (acc *Account) ServerSideTransferEnd(n int64) {
acc.stats.Bytes(n) acc.stats.Bytes(n)
} }
// serverSideEnd accounts for non specific server side data
func (acc *Account) serverSideEnd(n int64) {
// Account for bytes unless we are checking
if !acc.checking {
acc.stats.BytesNoNetwork(n)
}
}
// ServerSideCopyEnd accounts for a read of n bytes in a sever side copy // ServerSideCopyEnd accounts for a read of n bytes in a sever side copy
func (acc *Account) ServerSideCopyEnd(n int64) { func (acc *Account) ServerSideCopyEnd(n int64) {
acc.stats.AddServerSideCopy(n) acc.stats.AddServerSideCopy(n)
acc.serverSideEnd(n)
} }
// ServerSideMoveEnd accounts for a read of n bytes in a sever side move // ServerSideMoveEnd accounts for a read of n bytes in a sever side move
func (acc *Account) ServerSideMoveEnd(n int64) { func (acc *Account) ServerSideMoveEnd(n int64) {
acc.stats.AddServerSideMove(n) acc.stats.AddServerSideMove(n)
acc.serverSideEnd(n)
} }
// DryRun accounts for statistics without running the operation // DryRun accounts for statistics without running the operation

View File

@ -527,6 +527,13 @@ func (s *StatsInfo) Bytes(bytes int64) {
s.bytes += bytes s.bytes += bytes
} }
// BytesNoNetwork updates the stats for bytes bytes but doesn't include the transfer stats
func (s *StatsInfo) BytesNoNetwork(bytes int64) {
s.mu.Lock()
defer s.mu.Unlock()
s.bytes += bytes
}
// GetBytes returns the number of bytes transferred so far // GetBytes returns the number of bytes transferred so far
func (s *StatsInfo) GetBytes() int64 { func (s *StatsInfo) GetBytes() int64 {
s.mu.RLock() s.mu.RLock()

View File

@ -149,6 +149,7 @@ func (tr *Transfer) Account(ctx context.Context, in io.ReadCloser) *Account {
} else { } else {
tr.acc.UpdateReader(ctx, in) tr.acc.UpdateReader(ctx, in)
} }
tr.acc.checking = tr.checking
tr.mu.Unlock() tr.mu.Unlock()
return tr.acc return tr.acc
} }