mirror of
https://github.com/rclone/rclone.git
synced 2025-01-06 22:40:24 +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
771ec943f2
commit
ad8bde69b3
@ -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
|
||||||
|
@ -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()
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user