mirror of
https://github.com/rclone/rclone.git
synced 2025-01-11 00:40:03 +01:00
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
@ -49,17 +49,18 @@ type Account struct {
|
||||
// in http transport calls Read() after Do() returns on
|
||||
// CancelRequest so this race can happen when it apparently
|
||||
// shouldn't.
|
||||
mu sync.Mutex // mutex protects these values
|
||||
in io.Reader
|
||||
ctx context.Context // current context for transfer - may change
|
||||
ci *fs.ConfigInfo
|
||||
origIn io.ReadCloser
|
||||
close io.Closer
|
||||
size int64
|
||||
name string
|
||||
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
|
||||
mu sync.Mutex // mutex protects these values
|
||||
in io.Reader
|
||||
ctx context.Context // current context for transfer - may change
|
||||
ci *fs.ConfigInfo
|
||||
origIn io.ReadCloser
|
||||
close io.Closer
|
||||
size int64
|
||||
name string
|
||||
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 New Issue
Block a user