|
@ -11,6 +11,7 @@ import ( |
|
|
) |
|
|
) |
|
|
|
|
|
|
|
|
var ( |
|
|
var ( |
|
|
|
|
|
EnableBytesCache = true |
|
|
bytesCache *lru.Cache |
|
|
bytesCache *lru.Cache |
|
|
bytesPool *util.BytesPool |
|
|
bytesPool *util.BytesPool |
|
|
) |
|
|
) |
|
@ -48,12 +49,14 @@ func (block *Block) increaseReference() { |
|
|
func getBytesForFileBlock(r *os.File, offset int64, readSize int) (dataSlice []byte, block *Block, err error) { |
|
|
func getBytesForFileBlock(r *os.File, offset int64, readSize int) (dataSlice []byte, block *Block, err error) { |
|
|
// check cache, return if found
|
|
|
// check cache, return if found
|
|
|
cacheKey := fmt.Sprintf("%d:%d:%d", r.Fd(), offset>>3, readSize) |
|
|
cacheKey := fmt.Sprintf("%d:%d:%d", r.Fd(), offset>>3, readSize) |
|
|
|
|
|
if EnableBytesCache { |
|
|
if obj, found := bytesCache.Get(cacheKey); found { |
|
|
if obj, found := bytesCache.Get(cacheKey); found { |
|
|
block = obj.(*Block) |
|
|
block = obj.(*Block) |
|
|
block.increaseReference() |
|
|
block.increaseReference() |
|
|
dataSlice = block.Bytes[0:readSize] |
|
|
dataSlice = block.Bytes[0:readSize] |
|
|
return dataSlice, block, nil |
|
|
return dataSlice, block, nil |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// get the []byte from pool
|
|
|
// get the []byte from pool
|
|
|
b := bytesPool.Get(readSize) |
|
|
b := bytesPool.Get(readSize) |
|
@ -61,7 +64,9 @@ func getBytesForFileBlock(r *os.File, offset int64, readSize int) (dataSlice []b |
|
|
block = &Block{Bytes: b, refCount: 2} |
|
|
block = &Block{Bytes: b, refCount: 2} |
|
|
dataSlice = block.Bytes[0:readSize] |
|
|
dataSlice = block.Bytes[0:readSize] |
|
|
_, err = r.ReadAt(dataSlice, offset) |
|
|
_, err = r.ReadAt(dataSlice, offset) |
|
|
|
|
|
if EnableBytesCache { |
|
|
bytesCache.Add(cacheKey, block) |
|
|
bytesCache.Add(cacheKey, block) |
|
|
|
|
|
} |
|
|
return dataSlice, block, err |
|
|
return dataSlice, block, err |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|