aboutsummaryrefslogtreecommitdiff
path: root/weed/filesys/dir.go
diff options
context:
space:
mode:
authorChris Lu <chris.lu@gmail.com>2020-09-24 09:43:52 -0700
committerChris Lu <chris.lu@gmail.com>2020-09-24 09:43:52 -0700
commit2e7c361a0d5fe1217bc00512d7ac7bc5975dfb53 (patch)
tree29d001d01a51a13f09195261ba7df844b99be419 /weed/filesys/dir.go
parent1295347958e0954a5e1f053cd7ab52576fb8151e (diff)
downloadseaweedfs-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.go7
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