aboutsummaryrefslogtreecommitdiff
path: root/weed/storage/needle_map_memory.go
diff options
context:
space:
mode:
authorJaehoon Kim <kisow.github.io@navercorp.com>2025-10-17 04:21:51 +0900
committerGitHub <noreply@github.com>2025-10-16 12:21:51 -0700
commitd22e3d3495b962c7654414f7fa88b07ee06e4c16 (patch)
tree59bcc19409206137576542228d16b286d27ffdf6 /weed/storage/needle_map_memory.go
parent3d25f206c83e893d6dc5ea419a8702f0f44655e0 (diff)
downloadseaweedfs-d22e3d3495b962c7654414f7fa88b07ee06e4c16.tar.xz
seaweedfs-d22e3d3495b962c7654414f7fa88b07ee06e4c16.zip
Fix uncleanable orphans issue with `volume.fsck -forcePurging` (#7332)
- Modified `needle_map_memory.go` to include needles with size=0 during needle map loading - Updated `volume_write.go` to handle size=0 needles in delete operations
Diffstat (limited to 'weed/storage/needle_map_memory.go')
-rw-r--r--weed/storage/needle_map_memory.go2
1 files changed, 1 insertions, 1 deletions
diff --git a/weed/storage/needle_map_memory.go b/weed/storage/needle_map_memory.go
index c75514a31..c00c75010 100644
--- a/weed/storage/needle_map_memory.go
+++ b/weed/storage/needle_map_memory.go
@@ -36,7 +36,7 @@ func LoadCompactNeedleMap(file *os.File) (*NeedleMap, error) {
func doLoading(file *os.File, nm *NeedleMap) (*NeedleMap, error) {
e := idx.WalkIndexFile(file, 0, func(key NeedleId, offset Offset, size Size) error {
nm.MaybeSetMaxFileKey(key)
- if !offset.IsZero() && size.IsValid() {
+ if !offset.IsZero() && !size.IsDeleted() {
nm.FileCounter++
nm.FileByteCounter = nm.FileByteCounter + uint64(size)
oldOffset, oldSize := nm.m.Set(NeedleId(key), offset, size)