|
@ -9,12 +9,6 @@ import ( |
|
|
|
|
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb" |
|
|
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb" |
|
|
"github.com/chrislusf/seaweedfs/weed/util" |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
var ( |
|
|
|
|
|
concurrentWriterLimit = runtime.NumCPU() |
|
|
|
|
|
concurrentWriters = util.NewLimitedConcurrentExecutor(4 * concurrentWriterLimit) |
|
|
|
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
type ContinuousDirtyPages struct { |
|
|
type ContinuousDirtyPages struct { |
|
@ -33,7 +27,7 @@ func newDirtyPages(file *File) *ContinuousDirtyPages { |
|
|
dirtyPages := &ContinuousDirtyPages{ |
|
|
dirtyPages := &ContinuousDirtyPages{ |
|
|
intervals: &ContinuousIntervals{}, |
|
|
intervals: &ContinuousIntervals{}, |
|
|
f: file, |
|
|
f: file, |
|
|
chunkSaveErrChan: make(chan error, concurrentWriterLimit), |
|
|
|
|
|
|
|
|
chunkSaveErrChan: make(chan error, runtime.NumCPU()), |
|
|
} |
|
|
} |
|
|
go func() { |
|
|
go func() { |
|
|
for t := range dirtyPages.chunkSaveErrChan { |
|
|
for t := range dirtyPages.chunkSaveErrChan { |
|
@ -100,14 +94,18 @@ func (pages *ContinuousDirtyPages) saveExistingLargestPageToStorage() (hasSavedD |
|
|
|
|
|
|
|
|
func (pages *ContinuousDirtyPages) saveToStorage(reader io.Reader, offset int64, size int64) { |
|
|
func (pages *ContinuousDirtyPages) saveToStorage(reader io.Reader, offset int64, size int64) { |
|
|
|
|
|
|
|
|
|
|
|
errChanSize := pages.f.wfs.option.ConcurrentWriters |
|
|
|
|
|
if errChanSize == 0 { |
|
|
|
|
|
errChanSize = runtime.NumCPU() |
|
|
|
|
|
} |
|
|
if pages.chunkSaveErrChanClosed { |
|
|
if pages.chunkSaveErrChanClosed { |
|
|
pages.chunkSaveErrChan = make(chan error, concurrentWriterLimit) |
|
|
|
|
|
|
|
|
pages.chunkSaveErrChan = make(chan error, errChanSize) |
|
|
pages.chunkSaveErrChanClosed = false |
|
|
pages.chunkSaveErrChanClosed = false |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
mtime := time.Now().UnixNano() |
|
|
mtime := time.Now().UnixNano() |
|
|
pages.writeWaitGroup.Add(1) |
|
|
pages.writeWaitGroup.Add(1) |
|
|
go func() { |
|
|
|
|
|
|
|
|
writer := func() { |
|
|
defer pages.writeWaitGroup.Done() |
|
|
defer pages.writeWaitGroup.Done() |
|
|
|
|
|
|
|
|
reader = io.LimitReader(reader, size) |
|
|
reader = io.LimitReader(reader, size) |
|
@ -121,7 +119,13 @@ func (pages *ContinuousDirtyPages) saveToStorage(reader io.Reader, offset int64, |
|
|
pages.collection, pages.replication = collection, replication |
|
|
pages.collection, pages.replication = collection, replication |
|
|
pages.f.addChunks([]*filer_pb.FileChunk{chunk}) |
|
|
pages.f.addChunks([]*filer_pb.FileChunk{chunk}) |
|
|
glog.V(3).Infof("%s saveToStorage [%d,%d)", pages.f.fullpath(), offset, offset+size) |
|
|
glog.V(3).Infof("%s saveToStorage [%d,%d)", pages.f.fullpath(), offset, offset+size) |
|
|
}() |
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if pages.f.wfs.concurrentWriters != nil { |
|
|
|
|
|
pages.f.wfs.concurrentWriters.Execute(writer) |
|
|
|
|
|
} else { |
|
|
|
|
|
go writer() |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func max(x, y int64) int64 { |
|
|
func max(x, y int64) int64 { |
|
|