diff options
| author | chrislu <chris.lu@gmail.com> | 2022-08-07 10:14:01 -0700 |
|---|---|---|
| committer | chrislu <chris.lu@gmail.com> | 2022-08-07 10:14:01 -0700 |
| commit | 0aeec04c31ca8b559382eb7dfbdc09ccea6b9fe5 (patch) | |
| tree | 6a2ca00dfabeb81deae77c5cac22d54af245076a /weed/filer/reader_pattern.go | |
| parent | 928d29af9ec56a7ddbc574d7127814433140b5f9 (diff) | |
| download | seaweedfs-0aeec04c31ca8b559382eb7dfbdc09ccea6b9fe5.tar.xz seaweedfs-0aeec04c31ca8b559382eb7dfbdc09ccea6b9fe5.zip | |
quicker to adapt to pattern change
Diffstat (limited to 'weed/filer/reader_pattern.go')
| -rw-r--r-- | weed/filer/reader_pattern.go | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/weed/filer/reader_pattern.go b/weed/filer/reader_pattern.go index 38a51d788..e32f7fc2d 100644 --- a/weed/filer/reader_pattern.go +++ b/weed/filer/reader_pattern.go @@ -5,6 +5,8 @@ type ReaderPattern struct { lastReadStopOffset int64 } +const ModeChangeLimit = 3 + // For streaming read: only cache the first chunk // For random read: only fetch the requested range, instead of the whole chunk @@ -17,9 +19,13 @@ func NewReaderPattern() *ReaderPattern { func (rp *ReaderPattern) MonitorReadAt(offset int64, size int) { if rp.lastReadStopOffset == offset { - rp.isSequentialCounter++ + if rp.isSequentialCounter < ModeChangeLimit { + rp.isSequentialCounter++ + } } else { - rp.isSequentialCounter-- + if rp.isSequentialCounter > -ModeChangeLimit { + rp.isSequentialCounter-- + } } rp.lastReadStopOffset = offset + int64(size) } |
