forked from TrueCloudLab/rclone
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:
parent
dedad9f071
commit
d392f9fcd8
3 changed files with 30 additions and 11 deletions
|
@ -60,6 +60,7 @@ type Account struct {
|
|||
closed bool // set if the file is closed
|
||||
exit chan struct{} // channel that will be closed when transfer is finished
|
||||
withBuf bool // is using a buffered in
|
||||
checking bool // set if attached transfer is checking
|
||||
|
||||
tokenBucket buckets // per file bandwidth limiter (may be nil)
|
||||
|
||||
|
@ -295,14 +296,24 @@ func (acc *Account) ServerSideTransferEnd(n int64) {
|
|||
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
|
||||
func (acc *Account) ServerSideCopyEnd(n int64) {
|
||||
acc.stats.AddServerSideCopy(n)
|
||||
acc.serverSideEnd(n)
|
||||
}
|
||||
|
||||
// ServerSideMoveEnd accounts for a read of n bytes in a sever side move
|
||||
func (acc *Account) ServerSideMoveEnd(n int64) {
|
||||
acc.stats.AddServerSideMove(n)
|
||||
acc.serverSideEnd(n)
|
||||
}
|
||||
|
||||
// DryRun accounts for statistics without running the operation
|
||||
|
|
|
@ -527,6 +527,13 @@ func (s *StatsInfo) Bytes(bytes int64) {
|
|||
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
|
||||
func (s *StatsInfo) GetBytes() int64 {
|
||||
s.mu.RLock()
|
||||
|
|
|
@ -149,6 +149,7 @@ func (tr *Transfer) Account(ctx context.Context, in io.ReadCloser) *Account {
|
|||
} else {
|
||||
tr.acc.UpdateReader(ctx, in)
|
||||
}
|
||||
tr.acc.checking = tr.checking
|
||||
tr.mu.Unlock()
|
||||
return tr.acc
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue