Skip to content

Commit

Permalink
perf: remove duplicated rootkey fetch inpruning (9% pruning speedup o…
Browse files Browse the repository at this point in the history
…n osmosis) (backport #1026) (#1028)

Co-authored-by: Dev Ojha <ValarDragon@users.noreply.github.com>
  • Loading branch information
mergify[bot] and ValarDragon authored Dec 27, 2024
1 parent dfc90b0 commit 4a25346
Showing 1 changed file with 27 additions and 4 deletions.
31 changes: 27 additions & 4 deletions nodedb.go
Original file line number Diff line number Diff line change
Expand Up @@ -417,10 +417,32 @@ func (ndb *nodeDB) saveNodeFromPruning(node *Node) error {
return ndb.batch.Set(ndb.nodeKey(node.GetKey()), buf.Bytes())
}

type rootkeyCache struct {
version int64
rootKey []byte
}

func (rkc *rootkeyCache) getRootKey(ndb *nodeDB, version int64) ([]byte, error) {
if rkc.version == version {
return rkc.rootKey, nil
}
rootKey, err := ndb.GetRoot(version)
if err != nil {
return nil, err
}
rkc.setRootKey(version, rootKey)
return rootKey, nil
}

func (rkc *rootkeyCache) setRootKey(version int64, rootKey []byte) {
rkc.version = version
rkc.rootKey = rootKey
}

// deleteVersion deletes a tree version from disk.
// deletes orphans
func (ndb *nodeDB) deleteVersion(version int64) error {
rootKey, err := ndb.GetRoot(version)
func (ndb *nodeDB) deleteVersion(version int64, cache *rootkeyCache) error {
rootKey, err := cache.getRootKey(ndb, version)
if err != nil {
return err
}
Expand Down Expand Up @@ -458,7 +480,7 @@ func (ndb *nodeDB) deleteVersion(version int64) error {
}

// check if the version is referred by the next version
nextRootKey, err := ndb.GetRoot(version + 1)
nextRootKey, err := cache.getRootKey(ndb, version+1)
if err != nil {
return err
}
Expand Down Expand Up @@ -685,8 +707,9 @@ func (ndb *nodeDB) deleteVersionsTo(toVersion int64) error {
ndb.resetLegacyLatestVersion(-1)
}

rootkeyCache := &rootkeyCache{}
for version := first; version <= toVersion; version++ {
if err := ndb.deleteVersion(version); err != nil {
if err := ndb.deleteVersion(version, rootkeyCache); err != nil {
return err
}
ndb.resetFirstVersion(version + 1)
Expand Down

0 comments on commit 4a25346

Please sign in to comment.