diff options
| author | Chris Lu <chris.lu@gmail.com> | 2020-09-24 09:43:52 -0700 |
|---|---|---|
| committer | Chris Lu <chris.lu@gmail.com> | 2020-09-24 09:43:52 -0700 |
| commit | 2e7c361a0d5fe1217bc00512d7ac7bc5975dfb53 (patch) | |
| tree | 29d001d01a51a13f09195261ba7df844b99be419 /weed/filesys/dir.go | |
| parent | 1295347958e0954a5e1f053cd7ab52576fb8151e (diff) | |
| download | seaweedfs-2e7c361a0d5fe1217bc00512d7ac7bc5975dfb53.tar.xz seaweedfs-2e7c361a0d5fe1217bc00512d7ac7bc5975dfb53.zip | |
hardlink deletion factors in hardlink counter
Diffstat (limited to 'weed/filesys/dir.go')
| -rw-r--r-- | weed/filesys/dir.go | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/weed/filesys/dir.go b/weed/filesys/dir.go index 2d378f7b0..574749ef0 100644 --- a/weed/filesys/dir.go +++ b/weed/filesys/dir.go @@ -331,7 +331,8 @@ func (dir *Dir) removeOneFile(req *fuse.RemoveRequest) error { // first, ensure the filer store can correctly delete glog.V(3).Infof("remove file: %v", req) - err = filer_pb.Remove(dir.wfs, dir.FullPath(), req.Name, false, false, false, false, []int32{dir.wfs.signature}) + isDeleteData := entry.HardLinkCounter <= 1 + err = filer_pb.Remove(dir.wfs, dir.FullPath(), req.Name, isDeleteData, false, false, false, []int32{dir.wfs.signature}) if err != nil { glog.V(3).Infof("not found remove file %s/%s: %v", dir.FullPath(), req.Name, err) return fuse.ENOENT @@ -342,7 +343,9 @@ func (dir *Dir) removeOneFile(req *fuse.RemoveRequest) error { dir.wfs.fsNodeCache.DeleteFsNode(filePath) // delete the chunks last - dir.wfs.deleteFileChunks(entry.Chunks) + if isDeleteData { + dir.wfs.deleteFileChunks(entry.Chunks) + } return nil |
