diff options
Diffstat (limited to 'weed/mount/page_writer_pattern.go')
| -rw-r--r-- | weed/mount/page_writer_pattern.go | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/weed/mount/page_writer_pattern.go b/weed/mount/page_writer_pattern.go index 1ec9c9d4c..1ebcc19eb 100644 --- a/weed/mount/page_writer_pattern.go +++ b/weed/mount/page_writer_pattern.go @@ -6,6 +6,8 @@ type WriterPattern struct { chunkSize int64 } +const ModeChangeLimit = 3 + // For streaming write: only cache the first chunk // For random write: fall back to temp file approach // writes can only change from streaming mode to non-streaming mode @@ -20,9 +22,13 @@ func NewWriterPattern(chunkSize int64) *WriterPattern { func (rp *WriterPattern) MonitorWriteAt(offset int64, size int) { if rp.lastWriteStopOffset == offset { - rp.isSequentialCounter++ + if rp.isSequentialCounter < ModeChangeLimit { + rp.isSequentialCounter++ + } } else { - rp.isSequentialCounter-- + if rp.isSequentialCounter > -ModeChangeLimit { + rp.isSequentialCounter-- + } } rp.lastWriteStopOffset = offset + int64(size) } |
