seaweedfs/weed/storage/needle_map_memory.go

86 lines
2.4 KiB
Go
Raw Normal View History

package storage
import (
"os"
"github.com/chrislusf/seaweedfs/weed/glog"
"github.com/chrislusf/seaweedfs/weed/storage/idx"
2019-04-19 04:43:36 +00:00
"github.com/chrislusf/seaweedfs/weed/storage/needle_map"
. "github.com/chrislusf/seaweedfs/weed/storage/types"
)
type NeedleMap struct {
baseNeedleMapper
m needle_map.NeedleValueMap
}
2017-05-27 05:51:25 +00:00
func NewCompactNeedleMap(file *os.File) *NeedleMap {
nm := &NeedleMap{
2019-04-19 04:43:36 +00:00
m: needle_map.NewCompactMap(),
2017-05-27 05:51:25 +00:00
}
nm.indexFile = file
return nm
}
func LoadCompactNeedleMap(file *os.File) (*NeedleMap, error) {
nm := NewCompactNeedleMap(file)
return doLoading(file, nm)
}
func doLoading(file *os.File, nm *NeedleMap) (*NeedleMap, error) {
e := idx.WalkIndexFile(file, func(key NeedleId, offset Offset, size Size) error {
2019-04-15 06:00:37 +00:00
nm.MaybeSetMaxFileKey(key)
2020-09-10 21:42:50 +00:00
if !offset.IsZero() {
nm.FileCounter++
nm.FileByteCounter = nm.FileByteCounter + uint64(size)
2020-09-10 21:42:50 +00:00
oldOffset, oldSize := nm.m.Set(NeedleId(key), offset, size)
2020-08-19 01:01:37 +00:00
if !oldOffset.IsZero() && oldSize.IsValid() {
nm.DeletionCounter++
nm.DeletionByteCounter = nm.DeletionByteCounter + uint64(oldSize)
2020-09-10 21:42:50 +00:00
} else if size < 0 {
// deletion
nm.DeletionCounter++
nm.DeletionByteCounter = nm.DeletionByteCounter + uint64(-size)
}
} else {
oldSize := nm.m.Delete(NeedleId(key))
nm.DeletionCounter++
nm.DeletionByteCounter = nm.DeletionByteCounter + uint64(oldSize)
}
return nil
})
2019-04-15 06:00:37 +00:00
glog.V(1).Infof("max file key: %d for file: %s", nm.MaxFileKey(), file.Name())
return nm, e
}
func (nm *NeedleMap) Put(key NeedleId, offset Offset, size Size) error {
_, oldSize := nm.m.Set(NeedleId(key), offset, size)
nm.logPut(key, oldSize, size)
return nm.appendToIndexFile(key, offset, size)
}
2020-09-10 21:42:50 +00:00
func (nm *NeedleMap) Get(key NeedleId) (existingValue *needle_map.NeedleValue, ok bool) {
existingValue, ok = nm.m.Get(NeedleId(key))
return
}
2020-09-10 21:42:50 +00:00
func (nm *NeedleMap) Delete(key NeedleId) error {
existingValue, ok := nm.m.Get(NeedleId(key))
2020-09-12 11:08:03 +00:00
if !ok || existingValue.Size.IsDeleted() {
2020-09-10 21:42:50 +00:00
return nil
}
deletedBytes := nm.m.Delete(NeedleId(key))
nm.logDelete(deletedBytes)
2020-09-10 21:42:50 +00:00
return nm.appendToIndexFile(key, existingValue.Offset, -existingValue.Size)
}
func (nm *NeedleMap) Close() {
indexFileName := nm.indexFile.Name()
if err := nm.indexFile.Sync(); err != nil {
glog.Warningf("sync file %s failed, %v", indexFileName, err)
}
_ = nm.indexFile.Close()
}
func (nm *NeedleMap) Destroy() error {
nm.Close()
return os.Remove(nm.indexFile.Name())
}