mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2025-01-18 14:41:31 +08:00
fix resetting fh.reader
This commit is contained in:
parent
185332b91f
commit
e2ecf137a2
@ -98,16 +98,15 @@ func (fh *FileHandle) AddChunks(chunks []*filer_pb.FileChunk) {
|
|||||||
fh.entryViewCache = nil
|
fh.entryViewCache = nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (fh *FileHandle) SetReader(reader *filer.ChunkReadAt) {
|
func (fh *FileHandle) CloseReader() {
|
||||||
if fh.reader != nil {
|
if fh.reader != nil {
|
||||||
fh.reader.Close()
|
fh.reader.Close()
|
||||||
}
|
}
|
||||||
fh.reader = reader
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (fh *FileHandle) Release() {
|
func (fh *FileHandle) Release() {
|
||||||
fh.dirtyPages.Destroy()
|
fh.dirtyPages.Destroy()
|
||||||
fh.SetReader(nil)
|
fh.CloseReader()
|
||||||
}
|
}
|
||||||
|
|
||||||
func lessThan(a, b *filer_pb.FileChunk) bool {
|
func lessThan(a, b *filer_pb.FileChunk) bool {
|
||||||
|
@ -62,21 +62,19 @@ func (fh *FileHandle) readFromChunks(buff []byte, offset int64) (int64, error) {
|
|||||||
if chunkResolveErr != nil {
|
if chunkResolveErr != nil {
|
||||||
return 0, fmt.Errorf("fail to resolve chunk manifest: %v", chunkResolveErr)
|
return 0, fmt.Errorf("fail to resolve chunk manifest: %v", chunkResolveErr)
|
||||||
}
|
}
|
||||||
fh.SetReader(nil)
|
fh.CloseReader()
|
||||||
}
|
}
|
||||||
|
|
||||||
reader := fh.reader
|
if fh.reader == nil {
|
||||||
if reader == nil {
|
|
||||||
chunkViews := filer.ViewFromVisibleIntervals(fh.entryViewCache, 0, fileSize)
|
chunkViews := filer.ViewFromVisibleIntervals(fh.entryViewCache, 0, fileSize)
|
||||||
glog.V(4).Infof("file handle read %s [%d,%d) from %d views", fileFullPath, offset, offset+int64(len(buff)), len(chunkViews))
|
glog.V(4).Infof("file handle read %s [%d,%d) from %d views", fileFullPath, offset, offset+int64(len(buff)), len(chunkViews))
|
||||||
for _, chunkView := range chunkViews {
|
for _, chunkView := range chunkViews {
|
||||||
glog.V(4).Infof(" read %s [%d,%d) from chunk %+v", fileFullPath, chunkView.LogicOffset, chunkView.LogicOffset+int64(chunkView.Size), chunkView.FileId)
|
glog.V(4).Infof(" read %s [%d,%d) from chunk %+v", fileFullPath, chunkView.LogicOffset, chunkView.LogicOffset+int64(chunkView.Size), chunkView.FileId)
|
||||||
}
|
}
|
||||||
reader = filer.NewChunkReaderAtFromClient(fh.wfs.LookupFn(), chunkViews, fh.wfs.chunkCache, fileSize)
|
fh.reader = filer.NewChunkReaderAtFromClient(fh.wfs.LookupFn(), chunkViews, fh.wfs.chunkCache, fileSize)
|
||||||
}
|
}
|
||||||
fh.SetReader(reader)
|
|
||||||
|
|
||||||
totalRead, err := reader.ReadAt(buff, offset)
|
totalRead, err := fh.reader.ReadAt(buff, offset)
|
||||||
|
|
||||||
if err != nil && err != io.EOF {
|
if err != nil && err != io.EOF {
|
||||||
glog.Errorf("file handle read %s: %v", fileFullPath, err)
|
glog.Errorf("file handle read %s: %v", fileFullPath, err)
|
||||||
|
Loading…
Reference in New Issue
Block a user