Write the cache file to the cacheStorage.rootpath dir (#25715)

Signed-off-by: xige-16 <xi.ge@zilliz.com>
pull/25982/head
xige-16 2023-07-28 10:59:02 +08:00 committed by GitHub
parent d7cd1c849d
commit f33451b3d8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 48 additions and 20 deletions

View File

@ -19,6 +19,7 @@ package storage
import (
"context"
"io"
"path"
"sync"
"time"
@ -91,9 +92,10 @@ func (vcm *VectorChunkManager) initCache(ctx context.Context) error {
if err != nil {
log.Error("close mmap file failed", zap.Any("file", filePath))
}
err = vcm.cacheStorage.Remove(ctx, filePath)
localPath := path.Join(vcm.cacheStorage.RootPath(), filePath)
err = vcm.cacheStorage.Remove(ctx, localPath)
if err != nil {
log.Error("cache storage remove file failed", zap.Any("file", filePath))
log.Error("cache storage remove file failed", zap.Any("file", localPath))
}
vcm.cacheSizeMutex.Lock()
@ -173,12 +175,13 @@ func (vcm *VectorChunkManager) readFile(ctx context.Context, filePath string) (*
if err != nil {
return nil, err
}
err = vcm.cacheStorage.Write(ctx, filePath, results)
localPath := path.Join(vcm.cacheStorage.RootPath(), filePath)
err = vcm.cacheStorage.Write(ctx, localPath, results)
if err != nil {
return nil, err
}
r, err := vcm.cacheStorage.Mmap(ctx, filePath)
r, err := vcm.cacheStorage.Mmap(ctx, localPath)
if err != nil {
return nil, err
}

View File

@ -115,23 +115,21 @@ func initBinlogFile(schema *etcdpb.CollectionMeta) []*Blob {
return blobs
}
func buildVectorChunkManager(localPath string, localCacheEnable bool) (*VectorChunkManager, context.CancelFunc, error) {
ctx, cancel := context.WithCancel(context.Background())
func buildVectorChunkManager(ctx context.Context, localPath string, localCacheEnable bool) (*VectorChunkManager, error) {
bucketName := "vector-chunk-manager"
rcm, err := newMinIOChunkManager(ctx, bucketName, "")
if err != nil {
return nil, cancel, err
return nil, err
}
lcm := NewLocalChunkManager(RootPath(localPath))
vcm, err := NewVectorChunkManager(ctx, lcm, rcm, 16, localCacheEnable)
if err != nil {
return nil, cancel, err
return nil, err
}
return vcm, cancel, nil
return vcm, nil
}
var Params = paramtable.Get()
@ -171,7 +169,7 @@ func TestVectorChunkManager_GetPath(t *testing.T) {
defer cancel()
localCaches := []bool{true, false}
for _, localCache := range localCaches {
vcm, cancel, err := buildVectorChunkManager(localPath, localCache)
vcm, err := buildVectorChunkManager(ctx, localPath, localCache)
assert.NoError(t, err)
assert.NotNil(t, vcm)
@ -190,7 +188,6 @@ func TestVectorChunkManager_GetPath(t *testing.T) {
err = vcm.RemoveWithPrefix(ctx, localPath)
assert.NoError(t, err)
cancel()
vcm.Close()
}
}
@ -200,7 +197,7 @@ func TestVectorChunkManager_GetSize(t *testing.T) {
defer cancel()
localCaches := []bool{true, false}
for _, localCache := range localCaches {
vcm, cancel, err := buildVectorChunkManager(localPath, localCache)
vcm, err := buildVectorChunkManager(ctx, localPath, localCache)
assert.NoError(t, err)
assert.NotNil(t, vcm)
@ -219,7 +216,6 @@ func TestVectorChunkManager_GetSize(t *testing.T) {
err = vcm.RemoveWithPrefix(ctx, localPath)
assert.NoError(t, err)
cancel()
vcm.Close()
}
}
@ -230,7 +226,7 @@ func TestVectorChunkManager_Write(t *testing.T) {
localCaches := []bool{true, false}
for _, localCache := range localCaches {
vcm, cancel, err := buildVectorChunkManager(localPath, localCache)
vcm, err := buildVectorChunkManager(ctx, localPath, localCache)
assert.NoError(t, err)
assert.NotNil(t, vcm)
@ -259,7 +255,6 @@ func TestVectorChunkManager_Write(t *testing.T) {
err = vcm.RemoveWithPrefix(ctx, localPath)
assert.NoError(t, err)
cancel()
vcm.Close()
}
}
@ -270,7 +265,7 @@ func TestVectorChunkManager_Remove(t *testing.T) {
localCaches := []bool{true, false}
for _, localCache := range localCaches {
vcm, cancel, err := buildVectorChunkManager(localPath, localCache)
vcm, err := buildVectorChunkManager(ctx, localPath, localCache)
assert.NoError(t, err)
assert.NotNil(t, vcm)
@ -305,7 +300,6 @@ func TestVectorChunkManager_Remove(t *testing.T) {
err = vcm.RemoveWithPrefix(ctx, localPath)
assert.NoError(t, err)
cancel()
vcm.Close()
}
}
@ -348,13 +342,45 @@ func TestVectorChunkManager_Remove_Fail(t *testing.T) {
assert.Error(t, vcm.RemoveWithPrefix(ctx, "test"))
}
func TestVectorChunkManager_LocalPath(t *testing.T) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
vcm, err := buildVectorChunkManager(ctx, localPath, true)
assert.NotNil(t, vcm)
assert.NoError(t, err)
meta := initMeta()
binlogs := initBinlogFile(meta)
keys := make([]string, len(binlogs))
for i, binlog := range binlogs {
err = vcm.vectorStorage.Write(ctx, binlog.Key, binlog.Value)
assert.Nil(t, err)
keys[i] = binlog.Key
}
// cache file to cacheStorage
_, err = vcm.Read(ctx, keys[0])
assert.NoError(t, err)
// check file under cacheStorage.rootPath
absLocalPath := path.Join(vcm.cacheStorage.RootPath(), keys[0])
exit, err := vcm.cacheStorage.Exist(ctx, absLocalPath)
assert.NoError(t, err)
assert.True(t, exit)
err = vcm.RemoveWithPrefix(ctx, localPath)
assert.NoError(t, err)
vcm.Close()
}
func TestVectorChunkManager_Read(t *testing.T) {
ctx, cancel := context.WithCancel(context.Background())
defer cancel()
localCaches := []bool{true, false}
for _, localCache := range localCaches {
vcm, cancel, err := buildVectorChunkManager(localPath, localCache)
vcm, err := buildVectorChunkManager(ctx, localPath, localCache)
assert.NotNil(t, vcm)
assert.NoError(t, err)
@ -453,7 +479,6 @@ func TestVectorChunkManager_Read(t *testing.T) {
err = vcm.RemoveWithPrefix(ctx, localPath)
assert.NoError(t, err)
cancel()
vcm.Close()
}
}