mount: use direct_io to avoid OS page cache

fix https://github.com/chrislusf/seaweedfs/issues/1752
This commit is contained in:
Chris Lu 2021-01-22 22:39:46 -08:00
parent 711c3f3939
commit 20ef3bb8d4
4 changed files with 21 additions and 2 deletions

View file

@ -91,6 +91,9 @@ func (file *File) Getxattr(ctx context.Context, req *fuse.GetxattrRequest, resp
func (file *File) Open(ctx context.Context, req *fuse.OpenRequest, resp *fuse.OpenResponse) (fs.Handle, error) { func (file *File) Open(ctx context.Context, req *fuse.OpenRequest, resp *fuse.OpenResponse) (fs.Handle, error) {
glog.V(4).Infof("file %v open %+v", file.fullpath(), req) glog.V(4).Infof("file %v open %+v", file.fullpath(), req)
if USE_DIRECT_IO {
resp.Flags |= fuse.OpenDirectIO
}
handle := file.wfs.AcquireHandle(file, req.Uid, req.Gid) handle := file.wfs.AcquireHandle(file, req.Uid, req.Gid)

View file

@ -0,0 +1,8 @@
//+build darwin
package filesys
const (
USE_DIRECT_IO = false
)

View file

@ -0,0 +1,7 @@
//+build !darwin
package filesys
const (
USE_DIRECT_IO = true
)

View file

@ -90,8 +90,9 @@ func (fh *FileHandle) Read(ctx context.Context, req *fuse.ReadRequest, resp *fus
glog.Warningf("%s FileHandle Read %d: [%d,%d) size %d totalRead %d", fh.f.fullpath(), fh.handle, req.Offset, req.Offset+int64(req.Size), req.Size, totalRead) glog.Warningf("%s FileHandle Read %d: [%d,%d) size %d totalRead %d", fh.f.fullpath(), fh.handle, req.Offset, req.Offset+int64(req.Size), req.Size, totalRead)
totalRead = min(int64(len(buff)), totalRead) totalRead = min(int64(len(buff)), totalRead)
} }
// resp.Data = buff[:totalRead] if err == nil {
resp.Data = buff resp.Data = buff[:totalRead]
}
return err return err
} }