Browse Source

writer pattern: similar changes to reader pattern

pull/3317/head
chrislu 3 years ago
parent
commit
289402a741
  1. 34
      weed/mount/page_writer_pattern.go
  2. 2
      weed/mount/weedfs_file_write.go

34
weed/mount/page_writer_pattern.go

@ -1,8 +1,8 @@
package mount package mount
type WriterPattern struct { type WriterPattern struct {
isStreaming bool
lastWriteOffset int64
isSequentialCounter int64
lastWriteStopOffset int64
chunkSize int64 chunkSize int64
} }
@ -12,33 +12,21 @@ type WriterPattern struct {
func NewWriterPattern(chunkSize int64) *WriterPattern { func NewWriterPattern(chunkSize int64) *WriterPattern {
return &WriterPattern{ return &WriterPattern{
isStreaming: true,
lastWriteOffset: -1,
isSequentialCounter: 0,
lastWriteStopOffset: 0,
chunkSize: chunkSize, chunkSize: chunkSize,
} }
} }
func (rp *WriterPattern) MonitorWriteAt(offset int64, size int) { func (rp *WriterPattern) MonitorWriteAt(offset int64, size int) {
if rp.lastWriteOffset > offset {
rp.isStreaming = false
if rp.lastWriteStopOffset == offset {
rp.isSequentialCounter++
} else {
rp.isSequentialCounter--
} }
if rp.lastWriteOffset == -1 {
if offset != 0 {
rp.isStreaming = false
}
}
rp.lastWriteOffset = offset
}
func (rp *WriterPattern) IsStreamingMode() bool {
return rp.isStreaming
}
func (rp *WriterPattern) IsRandomMode() bool {
return !rp.isStreaming
rp.lastWriteStopOffset = offset + int64(size)
} }
func (rp *WriterPattern) Reset() {
rp.isStreaming = true
rp.lastWriteOffset = -1
func (rp *WriterPattern) IsSequentialMode() bool {
return rp.isSequentialCounter >= 0
} }

2
weed/mount/weedfs_file_write.go

@ -58,7 +58,7 @@ func (wfs *WFS) Write(cancel <-chan struct{}, in *fuse.WriteIn, data []byte) (wr
entry.Attributes.FileSize = uint64(max(offset+int64(len(data)), int64(entry.Attributes.FileSize))) entry.Attributes.FileSize = uint64(max(offset+int64(len(data)), int64(entry.Attributes.FileSize)))
// glog.V(4).Infof("%v write [%d,%d) %d", fh.f.fullpath(), req.Offset, req.Offset+int64(len(req.Data)), len(req.Data)) // glog.V(4).Infof("%v write [%d,%d) %d", fh.f.fullpath(), req.Offset, req.Offset+int64(len(req.Data)), len(req.Data))
fh.dirtyPages.AddPage(offset, data, fh.dirtyPages.writerPattern.IsStreamingMode())
fh.dirtyPages.AddPage(offset, data, fh.dirtyPages.writerPattern.IsSequentialMode())
written = uint32(len(data)) written = uint32(len(data))

Loading…
Cancel
Save