don't check legacy tables for pruning (#5116)

These tables can't be deleted from (read-only) and would be too slow to
delete from anyway due to the inefficient storage format in use.

* slow down startup clearing too
* remove unused del function
This commit is contained in:
Jacek Sieka 2023-06-24 16:14:28 +02:00 committed by Zahary Karadjov
parent 1bc9f3a67a
commit 17e74c0c8b
No known key found for this signature in database
GPG Key ID: C1F42EAFF38D570F
2 changed files with 18 additions and 18 deletions

View File

@ -885,18 +885,11 @@ proc delBlock*(db: BeaconChainDB, fork: ConsensusFork, key: Eth2Digest): bool =
proc delState*(db: BeaconChainDB, fork: ConsensusFork, key: Eth2Digest) = proc delState*(db: BeaconChainDB, fork: ConsensusFork, key: Eth2Digest) =
discard db.statesNoVal[fork].del(key.data).expectDb() discard db.statesNoVal[fork].del(key.data).expectDb()
proc clearBlocks*(db: BeaconChainDB, fork: ConsensusFork) = proc clearBlocks*(db: BeaconChainDB, fork: ConsensusFork): bool =
discard db.blocks[fork].clear().expectDb() db.blocks[fork].clear().expectDb()
proc clearStates*(db: BeaconChainDB, fork: ConsensusFork) = proc clearStates*(db: BeaconChainDB, fork: ConsensusFork): bool =
discard db.statesNoVal[fork].clear().expectDb() db.statesNoVal[fork].clear().expectDb()
proc delKeyValue*(db: BeaconChainDB, key: array[1, byte]) =
discard db.keyValues.del(key).expectDb()
discard db.v0.backend.del(key).expectDb()
proc delKeyValue*(db: BeaconChainDB, key: DbKeyKind) =
db.delKeyValue(subkey(key))
proc delStateRoot*(db: BeaconChainDB, root: Eth2Digest, slot: Slot) = proc delStateRoot*(db: BeaconChainDB, root: Eth2Digest, slot: Slot) =
discard db.stateRoots.del(stateRootKey(root, slot)).expectDb() discard db.stateRoots.del(stateRootKey(root, slot)).expectDb()

View File

@ -683,13 +683,13 @@ proc getState(
proc containsState*( proc containsState*(
db: BeaconChainDB, cfg: RuntimeConfig, block_root: Eth2Digest, db: BeaconChainDB, cfg: RuntimeConfig, block_root: Eth2Digest,
slots: Slice[Slot]): bool = slots: Slice[Slot], legacy = true): bool =
var slot = slots.b var slot = slots.b
while slot >= slots.a: while slot >= slots.a:
let state_root = db.getStateRoot(block_root, slot) let state_root = db.getStateRoot(block_root, slot)
if state_root.isSome() and if state_root.isSome() and
db.containsState( db.containsState(
cfg.consensusForkAtEpoch(slot.epoch), state_root.get()): cfg.consensusForkAtEpoch(slot.epoch), state_root.get(), legacy):
return true return true
if slot == slots.a: # avoid underflow at genesis if slot == slots.a: # avoid underflow at genesis
@ -2192,7 +2192,10 @@ proc pruneHistory*(dag: ChainDAGRef, startup = false) =
var first = true var first = true
while cur.isSome(): while cur.isSome():
let bs = cur.get() let bs = cur.get()
if dag.db.containsState(dag.cfg, bs.bid.root, bs.slot..bs.slot): # We don't delete legacy states because the legacy database is openend
# in read-only and slow to delete from due to its sub-optimal structure
if dag.db.containsState(
dag.cfg, bs.bid.root, bs.slot..bs.slot, legacy = first):
if first: if first:
# We leave the state on the prune horizon intact and update the tail # We leave the state on the prune horizon intact and update the tail
# to point to this state, indicating the new point in time from # to point to this state, indicating the new point in time from
@ -2252,17 +2255,21 @@ proc pruneHistory*(dag: ChainDAGRef, startup = false) =
# Once during start, we'll clear all "old fork" data - this ensures we get # Once during start, we'll clear all "old fork" data - this ensures we get
# rid of any leftover junk in the tables - we do so after linear pruning # rid of any leftover junk in the tables - we do so after linear pruning
# so as to "mostly" clean up the phase0 tables as well (which cannot be # so as to "mostly" clean up the phase0 tables as well (which cannot be
# pruned easily by fork) # pruned easily by fork) - one fork at a time, so as not to take too long
let stateFork = dag.cfg.consensusForkAtEpoch(dag.tail.slot.epoch) let stateFork = dag.cfg.consensusForkAtEpoch(dag.tail.slot.epoch)
var clearedStates = false
if stateFork > ConsensusFork.Phase0: if stateFork > ConsensusFork.Phase0:
for fork in ConsensusFork.Phase0..<stateFork: for fork in ConsensusFork.Phase0..<stateFork:
dag.db.clearStates(fork) if dag.db.clearStates(fork):
clearedStates = true
break
let blockFork = dag.cfg.consensusForkAtEpoch(blockHorizon.epoch) let blockFork = dag.cfg.consensusForkAtEpoch(blockHorizon.epoch)
if blockFork > ConsensusFork.Phase0: if not clearedStates and blockFork > ConsensusFork.Phase0:
for fork in ConsensusFork.Phase0..<blockFork: for fork in ConsensusFork.Phase0..<blockFork:
dag.db.clearBlocks(fork) if dag.db.clearBlocks(fork):
break
proc loadExecutionBlockHash*(dag: ChainDAGRef, bid: BlockId): Eth2Digest = proc loadExecutionBlockHash*(dag: ChainDAGRef, bid: BlockId): Eth2Digest =
if dag.cfg.consensusForkAtEpoch(bid.slot.epoch) < ConsensusFork.Bellatrix: if dag.cfg.consensusForkAtEpoch(bid.slot.epoch) < ConsensusFork.Bellatrix: