Browse Source

lock "addChunks()"

pull/1598/head
Chris Lu 4 years ago
parent
commit
0ae4d7bfdf
  1. 4
      weed/filesys/dirty_page.go

4
weed/filesys/dirty_page.go

@ -15,10 +15,10 @@ type ContinuousDirtyPages struct {
intervals *ContinuousIntervals intervals *ContinuousIntervals
f *File f *File
writeWaitGroup sync.WaitGroup writeWaitGroup sync.WaitGroup
chunkAddLock sync.Mutex
chunkSaveErrChan chan error chunkSaveErrChan chan error
chunkSaveErrChanClosed bool chunkSaveErrChanClosed bool
lastErr error lastErr error
lock sync.Mutex
collection string collection string
replication string replication string
} }
@ -117,6 +117,8 @@ func (pages *ContinuousDirtyPages) saveToStorage(reader io.Reader, offset int64,
} }
chunk.Mtime = mtime chunk.Mtime = mtime
pages.collection, pages.replication = collection, replication pages.collection, pages.replication = collection, replication
pages.chunkAddLock.Lock()
defer pages.chunkAddLock.Unlock()
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)
} }

Loading…
Cancel
Save