diff options
| author | Chris Lu <chris.lu@gmail.com> | 2017-01-06 10:22:20 -0800 |
|---|---|---|
| committer | Chris Lu <chris.lu@gmail.com> | 2017-01-06 10:22:20 -0800 |
| commit | 13e7069eb9cd72f94e72acb8fbbc9dd0307da703 (patch) | |
| tree | a093cbe0df8c2d06ea335e616bb5246f9c45ea04 /weed/storage/needle_map_memory.go | |
| parent | 54dd925283f443b09db77717c86eea5bf0f9d740 (diff) | |
| download | seaweedfs-13e7069eb9cd72f94e72acb8fbbc9dd0307da703.tar.xz seaweedfs-13e7069eb9cd72f94e72acb8fbbc9dd0307da703.zip | |
keep track of total data file size
Diffstat (limited to 'weed/storage/needle_map_memory.go')
| -rw-r--r-- | weed/storage/needle_map_memory.go | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/weed/storage/needle_map_memory.go b/weed/storage/needle_map_memory.go index 195d8bdbc..6fa929d90 100644 --- a/weed/storage/needle_map_memory.go +++ b/weed/storage/needle_map_memory.go @@ -33,7 +33,7 @@ func LoadNeedleMap(file *os.File) (*NeedleMap, error) { } nm.FileCounter++ nm.FileByteCounter = nm.FileByteCounter + uint64(size) - if offset > 0 { + if offset > 0 && size != TombstoneFileSize { 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 { @@ -92,10 +92,10 @@ func (nm *NeedleMap) Get(key uint64) (element *NeedleValue, ok bool) { element, ok = nm.m.Get(Key(key)) return } -func (nm *NeedleMap) Delete(key uint64) error { +func (nm *NeedleMap) Delete(key uint64, offset uint32) error { deletedBytes := nm.m.Delete(Key(key)) nm.logDelete(deletedBytes) - return nm.appendToIndexFile(key, 0, 0) + return nm.appendToIndexFile(key, offset, TombstoneFileSize) } func (nm *NeedleMap) Close() { _ = nm.indexFile.Close() |
