diff options
| author | Chris Lu <chris.lu@gmail.com> | 2018-07-08 02:28:04 -0700 |
|---|---|---|
| committer | Chris Lu <chris.lu@gmail.com> | 2018-07-08 02:28:04 -0700 |
| commit | d4d7ced922866e76e8c004d1c1045bcda2b25d5e (patch) | |
| tree | 199d7a8895ce1225ae5647cfaeb15cec6f73cf4f /weed/storage/needle_map_memory.go | |
| parent | 922032b9bb2c885d5f65d1f835878a8b2d39a2a6 (diff) | |
| download | seaweedfs-d4d7ced922866e76e8c004d1c1045bcda2b25d5e.tar.xz seaweedfs-d4d7ced922866e76e8c004d1c1045bcda2b25d5e.zip | |
refactoring: add type for needle id, offset
later the type size can possibly be adjusted
Diffstat (limited to 'weed/storage/needle_map_memory.go')
| -rw-r--r-- | weed/storage/needle_map_memory.go | 34 |
1 files changed, 18 insertions, 16 deletions
diff --git a/weed/storage/needle_map_memory.go b/weed/storage/needle_map_memory.go index cfdffe3d6..690ddd737 100644 --- a/weed/storage/needle_map_memory.go +++ b/weed/storage/needle_map_memory.go @@ -6,6 +6,7 @@ import ( "github.com/chrislusf/seaweedfs/weed/glog" "github.com/chrislusf/seaweedfs/weed/storage/needle" + . "github.com/chrislusf/seaweedfs/weed/storage/types" ) type NeedleMap struct { @@ -45,21 +46,21 @@ func LoadBtreeNeedleMap(file *os.File) (*NeedleMap, error) { } func doLoading(file *os.File, nm *NeedleMap) (*NeedleMap, error) { - e := WalkIndexFile(file, func(key uint64, offset, size uint32) error { + e := WalkIndexFile(file, func(key NeedleId, offset Offset, size uint32) error { if key > nm.MaximumFileKey { nm.MaximumFileKey = key } if offset > 0 && size != TombstoneFileSize { nm.FileCounter++ nm.FileByteCounter = nm.FileByteCounter + uint64(size) - oldOffset, oldSize := nm.m.Set(needle.Key(key), offset, size) + oldOffset, oldSize := nm.m.Set(NeedleId(key), offset, size) // glog.V(3).Infoln("reading key", key, "offset", offset*NeedlePaddingSize, "size", size, "oldSize", oldSize) if oldOffset > 0 && oldSize != TombstoneFileSize { nm.DeletionCounter++ nm.DeletionByteCounter = nm.DeletionByteCounter + uint64(oldSize) } } else { - oldSize := nm.m.Delete(needle.Key(key)) + oldSize := nm.m.Delete(NeedleId(key)) // glog.V(3).Infoln("removing key", key, "offset", offset*NeedlePaddingSize, "size", size, "oldSize", oldSize) nm.DeletionCounter++ nm.DeletionByteCounter = nm.DeletionByteCounter + uint64(oldSize) @@ -72,21 +73,22 @@ func doLoading(file *os.File, nm *NeedleMap) (*NeedleMap, error) { // walks through the index file, calls fn function with each key, offset, size // stops with the error returned by the fn function -func WalkIndexFile(r *os.File, fn func(key uint64, offset, size uint32) error) error { +func WalkIndexFile(r *os.File, fn func(key NeedleId, offset Offset, size uint32) error) error { var readerOffset int64 - bytes := make([]byte, NeedleIndexSize*RowsToRead) + bytes := make([]byte, NeedleEntrySize*RowsToRead) count, e := r.ReadAt(bytes, readerOffset) glog.V(3).Infoln("file", r.Name(), "readerOffset", readerOffset, "count", count, "e", e) readerOffset += int64(count) var ( - key uint64 - offset, size uint32 - i int + key NeedleId + offset Offset + size uint32 + i int ) for count > 0 && e == nil || e == io.EOF { - for i = 0; i+NeedleIndexSize <= count; i += NeedleIndexSize { - key, offset, size = idxFileEntry(bytes[i: i+NeedleIndexSize]) + for i = 0; i+NeedleEntrySize <= count; i += NeedleEntrySize { + key, offset, size = IdxFileEntry(bytes[i: i+NeedleEntrySize]) if e = fn(key, offset, size); e != nil { return e } @@ -101,17 +103,17 @@ func WalkIndexFile(r *os.File, fn func(key uint64, offset, size uint32) error) e return e } -func (nm *NeedleMap) Put(key uint64, offset uint32, size uint32) error { - _, oldSize := nm.m.Set(needle.Key(key), offset, size) +func (nm *NeedleMap) Put(key NeedleId, offset Offset, size uint32) error { + _, oldSize := nm.m.Set(NeedleId(key), offset, size) nm.logPut(key, oldSize, size) return nm.appendToIndexFile(key, offset, size) } -func (nm *NeedleMap) Get(key uint64) (element *needle.NeedleValue, ok bool) { - element, ok = nm.m.Get(needle.Key(key)) +func (nm *NeedleMap) Get(key NeedleId) (element *needle.NeedleValue, ok bool) { + element, ok = nm.m.Get(NeedleId(key)) return } -func (nm *NeedleMap) Delete(key uint64, offset uint32) error { - deletedBytes := nm.m.Delete(needle.Key(key)) +func (nm *NeedleMap) Delete(key NeedleId, offset Offset) error { + deletedBytes := nm.m.Delete(NeedleId(key)) nm.logDelete(deletedBytes) return nm.appendToIndexFile(key, offset, TombstoneFileSize) } |
