@ -141,9 +141,7 @@ func (dir *Dir) Create(ctx context.Context, req *fuse.CreateRequest,
return fuse . EIO
return fuse . EIO
}
}
if dir . wfs . option . AsyncMetaDataCaching {
dir . wfs . metaCache . InsertEntry ( context . Background ( ) , filer2 . FromPbEntry ( request . Directory , request . Entry ) )
dir . wfs . metaCache . InsertEntry ( context . Background ( ) , filer2 . FromPbEntry ( request . Directory , request . Entry ) )
}
return nil
return nil
} ) ; err != nil {
} ) ; err != nil {
@ -192,9 +190,7 @@ func (dir *Dir) Mkdir(ctx context.Context, req *fuse.MkdirRequest) (fs.Node, err
return err
return err
}
}
if dir . wfs . option . AsyncMetaDataCaching {
dir . wfs . metaCache . InsertEntry ( context . Background ( ) , filer2 . FromPbEntry ( request . Directory , request . Entry ) )
dir . wfs . metaCache . InsertEntry ( context . Background ( ) , filer2 . FromPbEntry ( request . Directory , request . Entry ) )
}
return nil
return nil
} )
} )
@ -219,13 +215,11 @@ func (dir *Dir) Lookup(ctx context.Context, req *fuse.LookupRequest, resp *fuse.
dirPath := util . FullPath ( dir . FullPath ( ) )
dirPath := util . FullPath ( dir . FullPath ( ) )
meta_cache . EnsureVisited ( dir . wfs . metaCache , dir . wfs , util . FullPath ( dirPath ) )
meta_cache . EnsureVisited ( dir . wfs . metaCache , dir . wfs , util . FullPath ( dirPath ) )
if dir . wfs . option . AsyncMetaDataCaching {
cachedEntry , cacheErr := dir . wfs . metaCache . FindEntry ( context . Background ( ) , fullFilePath )
cachedEntry , cacheErr := dir . wfs . metaCache . FindEntry ( context . Background ( ) , fullFilePath )
if cacheErr == filer_pb . ErrNotFound {
if cacheErr == filer_pb . ErrNotFound {
return nil , fuse . ENOENT
return nil , fuse . ENOENT
}
entry = cachedEntry . ToProtoEntry ( )
}
}
entry = cachedEntry . ToProtoEntry ( )
if entry == nil {
if entry == nil {
// glog.V(3).Infof("dir Lookup cache miss %s", fullFilePath)
// glog.V(3).Infof("dir Lookup cache miss %s", fullFilePath)
@ -283,25 +277,15 @@ func (dir *Dir) ReadDirAll(ctx context.Context) (ret []fuse.Dirent, err error) {
dirPath := util . FullPath ( dir . FullPath ( ) )
dirPath := util . FullPath ( dir . FullPath ( ) )
meta_cache . EnsureVisited ( dir . wfs . metaCache , dir . wfs , dirPath )
meta_cache . EnsureVisited ( dir . wfs . metaCache , dir . wfs , dirPath )
if dir . wfs . option . AsyncMetaDataCaching {
listedEntries , listErr := dir . wfs . metaCache . ListDirectoryEntries ( context . Background ( ) , util . FullPath ( dir . FullPath ( ) ) , "" , false , int ( dir . wfs . option . DirListCacheLimit ) )
listedEntries , listErr := dir . wfs . metaCache . ListDirectoryEntries ( context . Background ( ) , util . FullPath ( dir . FullPath ( ) ) , "" , false , int ( dir . wfs . option . DirListCacheLimit ) )
if listErr != nil {
if listErr != nil {
glog . Errorf ( "list meta cache: %v" , listErr )
glog . Errorf ( "list meta cache: %v" , listErr )
return nil , fuse . EIO
return nil , fuse . EIO
}
for _ , cachedEntry := range listedEntries {
processEachEntryFn ( cachedEntry . ToProtoEntry ( ) , false )
}
return
}
}
for _ , cachedEntry := range listedEntries {
readErr := filer_pb . ReadDirAllEntries ( dir . wfs , util . FullPath ( dir . FullPath ( ) ) , "" , processEachEntryFn )
processEachEntryFn ( cachedEntry . ToProtoEntry ( ) , false )
if readErr != nil {
glog . V ( 0 ) . Infof ( "list %s: %v" , dir . FullPath ( ) , err )
return ret , fuse . EIO
}
}
return
return ret , err
}
}
func ( dir * Dir ) Remove ( ctx context . Context , req * fuse . RemoveRequest ) error {
func ( dir * Dir ) Remove ( ctx context . Context , req * fuse . RemoveRequest ) error {
@ -330,9 +314,7 @@ func (dir *Dir) removeOneFile(req *fuse.RemoveRequest) error {
dir . wfs . cacheDelete ( filePath )
dir . wfs . cacheDelete ( filePath )
dir . wfs . fsNodeCache . DeleteFsNode ( filePath )
dir . wfs . fsNodeCache . DeleteFsNode ( filePath )
if dir . wfs . option . AsyncMetaDataCaching {
dir . wfs . metaCache . DeleteEntry ( context . Background ( ) , filePath )
dir . wfs . metaCache . DeleteEntry ( context . Background ( ) , filePath )
}
glog . V ( 3 ) . Infof ( "remove file: %v" , req )
glog . V ( 3 ) . Infof ( "remove file: %v" , req )
err = filer_pb . Remove ( dir . wfs , dir . FullPath ( ) , req . Name , false , false , false )
err = filer_pb . Remove ( dir . wfs , dir . FullPath ( ) , req . Name , false , false , false )
@ -351,9 +333,7 @@ func (dir *Dir) removeFolder(req *fuse.RemoveRequest) error {
dir . wfs . cacheDelete ( t )
dir . wfs . cacheDelete ( t )
dir . wfs . fsNodeCache . DeleteFsNode ( t )
dir . wfs . fsNodeCache . DeleteFsNode ( t )
if dir . wfs . option . AsyncMetaDataCaching {
dir . wfs . metaCache . DeleteEntry ( context . Background ( ) , t )
dir . wfs . metaCache . DeleteEntry ( context . Background ( ) , t )
}
glog . V ( 3 ) . Infof ( "remove directory entry: %v" , req )
glog . V ( 3 ) . Infof ( "remove directory entry: %v" , req )
err := filer_pb . Remove ( dir . wfs , dir . FullPath ( ) , req . Name , true , false , false )
err := filer_pb . Remove ( dir . wfs , dir . FullPath ( ) , req . Name , true , false , false )
@ -484,9 +464,7 @@ func (dir *Dir) saveEntry() error {
return fuse . EIO
return fuse . EIO
}
}
if dir . wfs . option . AsyncMetaDataCaching {
dir . wfs . metaCache . UpdateEntry ( context . Background ( ) , filer2 . FromPbEntry ( request . Directory , request . Entry ) )
dir . wfs . metaCache . UpdateEntry ( context . Background ( ) , filer2 . FromPbEntry ( request . Directory , request . Entry ) )
}
return nil
return nil
} )
} )
xxxxxxxxxx