mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-25 11:39:09 +00:00
13f51939f6
* Explicitly use shared `Kvt` table on `Ledger` and `Clique` lookup. why: Speeds up lookup time with `Aristo` backend. For writing `Clique` data, the `Companion` model allows to write `Clique` data past the database locked by evm transactions. * Implement `CoreDb` profiling with API tracking why: Chasing time spent per APT procs ... * Implement `Ledger` profiling with API tracking why: Chasing time spent per APT procs ... * Always hashify when commiting or storing why: A dirty cache makes no sense when committing * Make sure that a zero key is created when adding/updating vertices why: This is an error fix mainly for edge cases. A typical error was that the root key got deleted when there were only a few vertices left on the DB. * Need all created and changed vertices zero-keyed on the cache why: A zero key (i.e. empty Merkle hash) indicates that a vertex key needs to be updated. This would not be needed immediately after a merge as there is an actual leaf path on the cache layer. But after subsequent merge and delete operations this information might get blurred. * Re-org hashing algorithm why: Apart from errors, the previous implementation was too slow for two reasons: + some control hashes were calculated for debugging (now all verification is done in `aristo_check` module) + the leaf paths stored on the cache are used to build the labelling (aka hashing) schedule; there paths were accumulated over successive hash sessions although it is clear that all keys were generated, already
64 lines
1.8 KiB
Nim
64 lines
1.8 KiB
Nim
# Nimbus
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
# Licensed under either of
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
# http://www.apache.org/licenses/LICENSE-2.0)
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
# http://opensource.org/licenses/MIT)
|
|
# at your option. This file may not be copied, modified, or distributed
|
|
# except according to those terms.
|
|
|
|
## Unifies different ledger management APIs. All ledger objects are
|
|
## derived from the base objects
|
|
## ::
|
|
## LedgerRef => AccountsCache, overloaded AccountsCache, etc.
|
|
## LedgerSpRef => SavePoint, overloaded SavePoint etc
|
|
##
|
|
## In order to directly use `AccountsCache` it must be imported via
|
|
## `import db/ledger/accounts_cache`. In this case, there is no `LedgerRef`.
|
|
##
|
|
{.push raises: [].}
|
|
|
|
import
|
|
eth/common,
|
|
./core_db,
|
|
./ledger/backend/[
|
|
accounts_cache, accounts_cache_desc,
|
|
accounts_ledger, accounts_ledger_desc],
|
|
./ledger/base_iterators
|
|
|
|
import
|
|
./ledger/base except LedgerApiTxt, beginTrackApi, bless, ifTrackApi
|
|
|
|
export
|
|
AccountsCache,
|
|
AccountsLedgerRef,
|
|
LedgerType,
|
|
base,
|
|
base_iterators,
|
|
init
|
|
|
|
# ------------------------------------------------------------------------------
|
|
# Public constructor
|
|
# ------------------------------------------------------------------------------
|
|
|
|
proc init*(
|
|
ldgType: LedgerType;
|
|
db: CoreDbRef;
|
|
root: Hash256;
|
|
pruneTrie: bool;
|
|
): LedgerRef =
|
|
case ldgType:
|
|
of LegacyAccountsCache:
|
|
result = AccountsCache.init(db, root, pruneTrie)
|
|
|
|
of LedgerCache:
|
|
result = AccountsLedgerRef.init(db, root, pruneTrie)
|
|
|
|
else:
|
|
raiseAssert: "Missing ledger type label"
|
|
|
|
# ------------------------------------------------------------------------------
|
|
# End
|
|
# ------------------------------------------------------------------------------
|