diff options
| author | Chris Lu <chris.lu@gmail.com> | 2017-01-18 08:34:44 -0800 |
|---|---|---|
| committer | Chris Lu <chris.lu@gmail.com> | 2017-01-18 08:40:39 -0800 |
| commit | 59022b6fe00f25ceef8d7a027cbc90bf14f7605e (patch) | |
| tree | 815e5ce0367f4cc8db35db06d2a16734c62867c5 /weed/storage/needle_map_memory.go | |
| parent | 8b15523c9dae59b1338a54360ce3dbeadbae5124 (diff) | |
| download | seaweedfs-59022b6fe00f25ceef8d7a027cbc90bf14f7605e.tar.xz seaweedfs-59022b6fe00f25ceef8d7a027cbc90bf14f7605e.zip | |
fix byte counter on loading index file
fix https://github.com/chrislusf/seaweedfs/issues/441
Diffstat (limited to 'weed/storage/needle_map_memory.go')
| -rw-r--r-- | weed/storage/needle_map_memory.go | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/weed/storage/needle_map_memory.go b/weed/storage/needle_map_memory.go index 6fa929d90..ccbb21317 100644 --- a/weed/storage/needle_map_memory.go +++ b/weed/storage/needle_map_memory.go @@ -31,12 +31,12 @@ func LoadNeedleMap(file *os.File) (*NeedleMap, error) { if key > nm.MaximumFileKey { nm.MaximumFileKey = key } - nm.FileCounter++ - nm.FileByteCounter = nm.FileByteCounter + uint64(size) if offset > 0 && size != TombstoneFileSize { - oldSize := nm.m.Set(Key(key), offset, size) + nm.FileCounter++ + nm.FileByteCounter = nm.FileByteCounter + uint64(size) + oldOffset, oldSize := nm.m.Set(Key(key), offset, size) glog.V(3).Infoln("reading key", key, "offset", offset*NeedlePaddingSize, "size", size, "oldSize", oldSize) - if oldSize > 0 { + if oldOffset > 0 && oldSize != TombstoneFileSize { nm.DeletionCounter++ nm.DeletionByteCounter = nm.DeletionByteCounter + uint64(oldSize) } @@ -84,7 +84,7 @@ func WalkIndexFile(r *os.File, fn func(key uint64, offset, size uint32) error) e } func (nm *NeedleMap) Put(key uint64, offset uint32, size uint32) error { - oldSize := nm.m.Set(Key(key), offset, size) + _, oldSize := nm.m.Set(Key(key), offset, size) nm.logPut(key, oldSize, size) return nm.appendToIndexFile(key, offset, size) } |
