aboutsummaryrefslogtreecommitdiff
path: root/weed/storage/needle_map_memory.go
diff options
context:
space:
mode:
authorChris Lu <chris.lu@gmail.com>2017-01-06 10:22:20 -0800
committerChris Lu <chris.lu@gmail.com>2017-01-06 10:22:20 -0800
commit13e7069eb9cd72f94e72acb8fbbc9dd0307da703 (patch)
treea093cbe0df8c2d06ea335e616bb5246f9c45ea04 /weed/storage/needle_map_memory.go
parent54dd925283f443b09db77717c86eea5bf0f9d740 (diff)
downloadseaweedfs-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.go6
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()