erigon-pulse/erigon-lib/kv/tables.go

915 lines
29 KiB
Go
Raw Permalink Normal View History

2021-07-28 03:37:25 +00:00
/*
Copyright 2021 Erigon contributors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
2021-07-28 03:36:06 +00:00
package kv
import (
"fmt"
2021-07-28 03:36:06 +00:00
"sort"
"strings"
"github.com/ledgerwatch/erigon-lib/gointerfaces/types"
)
2022-03-19 04:38:37 +00:00
// DBSchemaVersion versions list
// 5.0 - BlockTransaction table now has canonical ids (txs of non-canonical blocks moving to NonCanonicalTransaction table)
// 6.0 - BlockTransaction table now has system-txs before and after block (records are absent if block has no system-tx, but sequence increasing)
2023-10-13 04:36:23 +00:00
// 6.1 - Canonical/NonCanonical/BadBlock transitions now stored in same table: kv.EthTx. Add kv.BadBlockNumber table
var DBSchemaVersion = types.VersionReply{Major: 6, Minor: 1, Patch: 0}
2021-07-28 03:36:06 +00:00
// ChaindataTables
// Dictionary:
// "Plain State" - state where keys arent' hashed. "CurrentState" - same, but keys are hashed. "PlainState" used for blocks execution. "CurrentState" used mostly for Merkle root calculation.
// "incarnation" - uint64 number - how much times given account was SelfDestruct'ed.
/*
PlainState logical layout:
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
Contains Accounts:
key - address (unhashed)
value - account encoded for storage
Contains Storage:
key - address (unhashed) + incarnation + storage key (unhashed)
value - storage value(common.hash)
Physical layout:
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
PlainState and HashedStorage utilises DupSort feature of MDBX (store multiple values inside 1 key).
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
-------------------------------------------------------------
2022-08-10 12:00:19 +00:00
key | value
2021-07-28 03:36:06 +00:00
-------------------------------------------------------------
[acc_hash] | [acc_value]
[acc_hash]+[inc] | [storage1_hash]+[storage1_value]
2022-08-10 12:00:19 +00:00
| [storage2_hash]+[storage2_value] // this value has no own key. it's 2nd value of [acc_hash]+[inc] key.
| [storage3_hash]+[storage3_value]
| ...
2021-07-28 03:36:06 +00:00
[acc_hash]+[old_inc] | [storage1_hash]+[storage1_value]
2022-08-10 12:00:19 +00:00
| ...
2021-07-28 03:36:06 +00:00
[acc2_hash] | [acc2_value]
2022-08-10 12:00:19 +00:00
...
2021-07-28 03:36:06 +00:00
*/
const PlainState = "PlainState"
2022-08-10 12:00:19 +00:00
// PlainContractCode -
// key - address+incarnation
// value - code hash
2021-07-28 03:36:06 +00:00
const PlainContractCode = "PlainCodeHash"
/*
AccountChangeSet and StorageChangeSet - of block N store values of state before block N changed them.
Because values "after" change stored in PlainState.
Logical format:
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
key - blockNum_u64 + key_in_plain_state
value - value_in_plain_state_before_blockNum_changes
Example: If block N changed account A from value X to Y. Then:
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
AccountChangeSet has record: bigEndian(N) + A -> X
PlainState has record: A -> Y
See also: docs/programmers_guide/db_walkthrough.MD#table-history-of-accounts
As you can see if block N changes much accounts - then all records have repetitive prefix `bigEndian(N)`.
MDBX can store such prefixes only once - by DupSort feature (see `docs/programmers_guide/dupsort.md`).
Both buckets are DupSort-ed and have physical format:
AccountChangeSet:
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
key - blockNum_u64
value - address + account(encoded)
StorageChangeSet:
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
key - blockNum_u64 + address + incarnation_u64
value - plain_storage_key + value
*/
const AccountChangeSet = "AccountChangeSet"
const StorageChangeSet = "StorageChangeSet"
const (
//HashedAccounts
// key - address hash
// value - account encoded for storage
// Contains Storage:
//key - address hash + incarnation + storage key hash
//value - storage value(common.hash)
HashedAccounts = "HashedAccount"
HashedStorage = "HashedStorage"
)
/*
AccountsHistory and StorageHistory - indices designed to serve next 2 type of requests:
1. what is smallest block number >= X where account A changed
2. get last shard of A - to append there new block numbers
Task 1. is part of "get historical state" operation (see `core/state:GetAsOf`):
If `db.Seek(A+bigEndian(X))` returns non-last shard -
2022-08-10 12:00:19 +00:00
then get block number from shard value Y := RoaringBitmap(shard_value).GetGte(X)
and with Y go to ChangeSets: db.Get(ChangeSets, Y+A)
2021-07-28 03:36:06 +00:00
If `db.Seek(A+bigEndian(X))` returns last shard -
2022-08-10 12:00:19 +00:00
then we go to PlainState: db.Get(PlainState, A)
2021-07-28 03:36:06 +00:00
Format:
2022-08-10 12:00:19 +00:00
- index split to shards by 2Kb - RoaringBitmap encoded sorted list of block numbers
(to avoid performance degradation of popular accounts or look deep into history.
Also 2Kb allows avoid Overflow pages inside DB.)
- if shard is not last - then key has suffix 8 bytes = bigEndian(max_block_num_in_this_shard)
- if shard is last - then key has suffix 8 bytes = 0xFF
2021-07-28 03:36:06 +00:00
It allows:
2022-08-10 12:00:19 +00:00
- server task 1. by 1 db operation db.Seek(A+bigEndian(X))
- server task 2. by 1 db operation db.Get(A+0xFF)
2021-07-28 03:36:06 +00:00
see also: docs/programmers_guide/db_walkthrough.MD#table-change-sets
AccountsHistory:
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
key - address + shard_id_u64
value - roaring bitmap - list of block where it changed
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
StorageHistory
2022-08-10 12:00:19 +00:00
2021-07-28 03:36:06 +00:00
key - address + storage_key + shard_id_u64
value - roaring bitmap - list of block where it changed
*/
2023-06-11 14:12:07 +00:00
const E2AccountsHistory = "AccountHistory"
const E2StorageHistory = "StorageHistory"
2021-07-28 03:36:06 +00:00
const (
//key - contract code hash
//value - contract code
Code = "Code"
//key - addressHash+incarnation
//value - code hash
ContractCode = "HashedCodeHash"
// IncarnationMap for deleted accounts
//key - address
//value - incarnation of account when it was last deleted
IncarnationMap = "IncarnationMap"
//TEVMCode -
//key - contract code hash
//value - contract TEVM code
ContractTEVMCode = "TEVMCode"
)
2022-08-10 12:00:19 +00:00
/*
TrieOfAccounts and TrieOfStorage
2021-07-28 03:36:06 +00:00
hasState,groups - mark prefixes existing in hashed_account table
hasTree - mark prefixes existing in trie_account table (not related with branchNodes)
hasHash - mark prefixes which hashes are saved in current trie_account record (actually only hashes of branchNodes can be saved)
@see UnmarshalTrieNode
@see integrity.Trie
+-----------------------------------------------------------------------------------------------------+
| DB record: 0x0B, hasState: 0b1011, hasTree: 0b1001, hasHash: 0b1001, hashes: [x,x] |
+-----------------------------------------------------------------------------------------------------+
2022-08-10 12:00:19 +00:00
| | |
v | v
2021-07-28 03:36:06 +00:00
+---------------------------------------------+ | +--------------------------------------+
| DB record: 0x0B00, hasState: 0b10001 | | | DB record: 0x0B03, hasState: 0b10010 |
| hasTree: 0, hasHash: 0b10000, hashes: [x] | | | hasTree: 0, hasHash: 0, hashes: [] |
+---------------------------------------------+ | +--------------------------------------+
2022-08-10 12:00:19 +00:00
| | | | |
v v v v v
2021-07-28 03:36:06 +00:00
+------------------+ +----------------------+ +---------------+ +---------------+ +---------------+
| Account: | | BranchNode: 0x0B0004 | | Account: | | Account: | | Account: |
| 0x0B0000... | | has no record in | | 0x0B01... | | 0x0B0301... | | 0x0B0304... |
| in HashedAccount | | TrieAccount | | | | | | |
+------------------+ +----------------------+ +---------------+ +---------------+ +---------------+
2022-08-10 12:00:19 +00:00
| |
v v
+---------------+ +---------------+
| Account: | | Account: |
| 0x0B000400... | | 0x0B000401... |
+---------------+ +---------------+
2021-07-28 03:36:06 +00:00
Invariants:
- hasTree is subset of hasState
- hasHash is subset of hasState
- first level in account_trie always exists if hasState>0
- TrieStorage record of account.root (length=40) must have +1 hash - it's account.root
- each record in TrieAccount table must have parent (may be not direct) and this parent must have correct bit in hasTree bitmap
- if hasState has bit - then HashedAccount table must have record according to this bit
- each TrieAccount record must cover some state (means hasState is always > 0)
- TrieAccount records with length=1 can satisfy (hasBranch==0&&hasHash==0) condition
- Other records in TrieAccount and TrieStorage must (hasTree!=0 || hasHash!=0)
*/
const TrieOfAccounts = "TrieAccount"
const TrieOfStorage = "TrieStorage"
2022-09-22 16:05:02 +00:00
// Mapping [block number] => [Verkle Root]
const VerkleRoots = "VerkleRoots"
// Mapping [Verkle Root] => [Rlp-Encoded Verkle Node]
const VerkleTrie = "VerkleTrie"
2021-07-28 03:36:06 +00:00
const (
// DatabaseInfo is used to store information about data layout.
DatabaseInfo = "DbInfo"
2021-07-28 03:36:06 +00:00
// Naming:
// NeaderNumber - Ethereum-specific block number. All nodes have same BlockNum.
// NeaderID - auto-increment ID. Depends on order in which node see headers.
// Invariant: for all headers in snapshots Number == ID. It means no reason to store Num/ID for this headers in DB.
// Same about: TxNum/TxID, BlockNum/BlockID
HeaderNumber = "HeaderNumber" // header_hash -> header_num_u64
BadHeaderNumber = "BadHeaderNumber" // header_hash -> header_num_u64
2021-07-28 03:36:06 +00:00
HeaderCanonical = "CanonicalHeader" // block_num_u64 -> header hash
Headers = "Header" // block_num_u64 + hash -> header (RLP)
HeaderTD = "HeadersTotalDifficulty" // block_num_u64 + hash -> td (RLP)
BlockBody = "BlockBody" // block_num_u64 + hash -> block body
2023-06-05 04:43:40 +00:00
// Naming:
// TxNum - Ethereum canonical transaction number - same across all nodes.
// TxnID - auto-increment ID - can be differrent across all nodes
// BlockNum/BlockID - same
//
// EthTx - stores all transactions of Canonical/NonCanonical/Bad blocks
// TxnID (auto-increment ID) - means nodes in network will have different ID of same transactions
// Snapshots (frozen data): using TxNum (not TxnID)
//
// During ReOrg - txs are not removed/updated
//
// Also this table has system-txs before and after block: if
2023-06-05 04:43:40 +00:00
// block has no system-tx - records are absent, but TxnID increasing
//
// In Erigon3: table MaxTxNum storing TxNum (not TxnID). History/Indices are using TxNum (not TxnID).
EthTx = "BlockTransaction" // tx_id_u64 -> rlp(tx)
NonCanonicalTxs = "NonCanonicalTransaction" // tbl_sequence_u64 -> rlp(tx)
MaxTxNum = "MaxTxNum" // block_number_u64 -> max_tx_num_in_block_u64
Receipts = "Receipt" // block_num_u64 -> canonical block receipts (non-canonical are not stored)
Log = "TransactionLog" // block_num_u64 + txId -> logs of transaction
2021-07-28 03:36:06 +00:00
// Stores bitmap indices - in which block numbers saw logs of given 'address' or 'topic'
// [addr or topic] + [2 bytes inverted shard number] -> bitmap(blockN)
// indices are sharded - because some bitmaps are >1Mb and when new incoming blocks process it
// updates ~300 of bitmaps - by append small amount new values. It cause much big writes (MDBX does copy-on-write).
//
// if last existing shard size merge it with delta
// if serialized size of delta > ShardLimit - break down to multiple shards
// shard number - it's biggest value in bitmap
LogTopicIndex = "LogTopicIndex"
LogAddressIndex = "LogAddressIndex"
// CallTraceSet is the name of the table that contain the mapping of block number to the set (sorted) of all accounts
// touched by call traces. It is DupSort-ed table
// 8-byte BE block number -> account address -> two bits (one for "from", another for "to")
CallTraceSet = "CallTraceSet"
// Indices for call traces - have the same format as LogTopicIndex and LogAddressIndex
// Store bitmap indices - in which block number we saw calls from (CallFromIndex) or to (CallToIndex) some addresses
CallFromIndex = "CallFromIndex"
CallToIndex = "CallToIndex"
2022-01-20 08:25:03 +00:00
// Cumulative indexes for estimation of stage execution
CumulativeGasIndex = "CumulativeGasIndex"
CumulativeTransactionIndex = "CumulativeTransactionIndex"
2021-07-28 03:36:06 +00:00
TxLookup = "BlockTransactionLookup" // hash -> transaction/receipt lookup metadata
ConfigTable = "Config" // config prefix for the db
// Progress of sync stages: stageName -> stageData
SyncStageProgress = "SyncStage"
Clique = "Clique"
CliqueSeparate = "CliqueSeparate"
CliqueSnapshot = "CliqueSnapshot"
CliqueLastSnapshot = "CliqueLastSnapshot"
// Proof-of-stake
// Beacon chain head that is been executed at the current time
CurrentExecutionPayload = "CurrentExecutionPayload"
// Node database tables (see nodedb.go)
// NodeRecords stores P2P node records (ENR)
NodeRecords = "NodeRecord"
// Inodes stores P2P discovery service info about the nodes
2021-07-28 03:36:06 +00:00
Inodes = "Inode"
// Transaction senders - stored separately from the block bodies
Senders = "TxSender" // block_num_u64 + blockHash -> sendersList (no serialization format, every 20 bytes is new sender)
// headBlockKey tracks the latest know full block's hash.
HeadBlockKey = "LastBlock"
HeadHeaderKey = "LastHeader"
// headBlockHash, safeBlockHash, finalizedBlockHash of the latest Engine API forkchoice
LastForkchoice = "LastForkchoice"
// TransitionBlockKey tracks the last proof-of-work block
TransitionBlockKey = "TransitionBlock"
2021-07-28 03:36:06 +00:00
// migrationName -> serialized SyncStageProgress and SyncStageUnwind buckets
// it stores stages progress to understand in which context was executed migration
// in case of bug-report developer can ask content of this bucket
Migrations = "Migration"
Sequence = "Sequence" // tbl_name -> seq_u64
2021-07-28 03:36:06 +00:00
Epoch = "DevEpoch" // block_num_u64+block_hash->transition_proof
PendingEpoch = "DevPendingEpoch" // block_num_u64+block_hash->transition_proof
2021-08-11 23:40:38 +00:00
2021-08-27 04:52:47 +00:00
Issuance = "Issuance" // block_num_u64->RLP(issuance+burnt[0 if < london])
[erigon2] Introduce commitment files and table (#201) * Introduce commitment files and table * Introduce commitment files and table * Introduce words buffer * Move changes out of aggregator into the writer * Start calc commitment * Add commitment package * More on hex patricia * More * account decorator * More * Add test * More * More to the test * Use hex in tests * More * More * More * More * Simplified cells * Add delBitmap * More advanced MockState * More compact unfolding * Separation of hashed Keys * Sepatate downHashedKey and upHashedKey * Carry extension node through accounts * optimised row allocations * Fix encoding/decoding, add trace flag * Added account and storage into the cells * Make accountKeyLen global setting * Remove BranchNodeUpdaqte intermediate * Started on computeHash * Initial hash calculations * Fix lint * Change account encoding * Fix commitment issues * Fix lint * Fix lint * Fix lint * Trace * Small fix and tracing * Print branch hashes, fix empty * Fix * Fix * Fix * Fix * Print accountFn * Trigger accountFn * Trigger accountFn * Another fix for extension nodes * Return root hash and set trace * Print depth for computeCellHash * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Ineffectual deletes * Trace needUnfolding * Fix * Fix * Fix * trace deletes * trace deletes * trace deletes * trace deletes * trace deletes * not overwrite downHashedKey in updateAccount * simplify needUnfolding * simplify needUnfolding * simplify needUnfolding * simplify needUnfolding * simplify needUnfolding * propagate deletes when unfolding * remove deletes when folding * remove deletes when folding * remove upHashedKey when delete cell * remove upHashedKey when delete cell * aggregate storage changes later * remove del bit when updating account * remove del bit when updating account * remove del bit when updating account * perform delete after code update * perform delete after code update * perform delete after code update * perform delete after code update * perform delete after code update * perform delete after code update * latest update has precedence when aggregating * Revert "latest update has precedence when aggregating" This reverts commit 0234ea6c3e1a0b2e7599df7c470d4b8b8d56736a. * latest update has precedence when aggregating * Revert "latest update has precedence when aggregating" This reverts commit cfa7b75327e4d5d1236f905c3c04eb640b21838d. * Introduce FinishTx * Separate commitment separation from computation * Prevent spurious delete * Spurious deletes * Trace param * Preserve upHashedKey when unfolding * Fix * Fix * Correctly compute firstInsert * Try to fix delete + fold * Remove commented out * updateStorage to remove deleted flag * rename upHashedKey to extension, fix clear-up * Carry extension up if account plain key is present * Carry extension up if account plain key is present * Not to fail for deleteAccount * Not to fail for deleteAccount * Not to fail for deleteAccount * Print * Print * Print * Print * Print * Print * Print * Print * Copy keys before putting them into commTree * Preserve changes to AccountData Co-authored-by: Alex Sharp <alexsharp@Alexs-MacBook-Pro.local> Co-authored-by: Alexey Sharp <alexeysharp@Alexeys-iMac.local>
2022-01-12 11:21:52 +00:00
StateAccounts = "StateAccounts"
StateStorage = "StateStorage"
StateCode = "StateCode"
StateCommitment = "StateCommitment"
// BOR
BorReceipts = "BorReceipt"
BorFinality = "BorFinality"
BorTxLookup = "BlockBorTransactionLookup" // transaction_hash -> block_num_u64
BorSeparate = "BorSeparate" // persisted snapshots of the Validator Sets, with their proposer priorities
BorEvents = "BorEvents" // event_id -> event_payload
BorEventNums = "BorEventNums" // block_num -> event_id (first event_id in that block)
BorSpans = "BorSpans" // span_id -> span (in JSON encoding)
// Downloader
BittorrentCompletion = "BittorrentCompletion"
BittorrentInfo = "BittorrentInfo"
2023-06-11 14:12:07 +00:00
// Domains/Histry/InvertedIndices
// Contants have "Tbl" prefix, to avoid collision with actual Domain names
// This constants is very rarely used in APP, but Domain/History/Idx names are widely used
TblAccountKeys = "AccountKeys"
TblAccountVals = "AccountVals"
TblAccountHistoryKeys = "AccountHistoryKeys"
TblAccountHistoryVals = "AccountHistoryVals"
TblAccountIdx = "AccountIdx"
TblStorageKeys = "StorageKeys"
TblStorageVals = "StorageVals"
TblStorageHistoryKeys = "StorageHistoryKeys"
TblStorageHistoryVals = "StorageHistoryVals"
TblStorageIdx = "StorageIdx"
TblCodeKeys = "CodeKeys"
TblCodeVals = "CodeVals"
TblCodeHistoryKeys = "CodeHistoryKeys"
TblCodeHistoryVals = "CodeHistoryVals"
TblCodeIdx = "CodeIdx"
TblCommitmentKeys = "CommitmentKeys"
TblCommitmentVals = "CommitmentVals"
TblCommitmentHistoryKeys = "CommitmentHistoryKeys"
TblCommitmentHistoryVals = "CommitmentHistoryVals"
TblCommitmentIdx = "CommitmentIdx"
TblLogAddressKeys = "LogAddressKeys"
TblLogAddressIdx = "LogAddressIdx"
TblLogTopicsKeys = "LogTopicsKeys"
TblLogTopicsIdx = "LogTopicsIdx"
TblTracesFromKeys = "TracesFromKeys"
TblTracesFromIdx = "TracesFromIdx"
TblTracesToKeys = "TracesToKeys"
TblTracesToIdx = "TracesToIdx"
2022-07-04 04:56:35 +00:00
Snapshots = "Snapshots" // name -> hash
2023-06-11 14:12:07 +00:00
//State Reconstitution
RAccountKeys = "RAccountKeys"
RAccountIdx = "RAccountIdx"
RStorageKeys = "RStorageKeys"
RStorageIdx = "RStorageIdx"
RCodeKeys = "RCodeKeys"
RCodeIdx = "RCodeIdx"
PlainStateR = "PlainStateR" // temporary table for PlainState reconstitution
PlainStateD = "PlainStateD" // temporary table for PlainStare reconstitution, deletes
CodeR = "CodeR" // temporary table for Code reconstitution
CodeD = "CodeD" // temporary table for Code reconstitution, deletes
PlainContractR = "PlainContractR" // temporary table for PlainContract reconstitution
PlainContractD = "PlainContractD" // temporary table for PlainContract reconstitution, deletes
2022-11-02 00:00:59 +00:00
2022-12-28 16:43:51 +00:00
// Erigon-CL Objects
// [slot] => [Beacon state]
2022-11-02 00:00:59 +00:00
BeaconState = "BeaconState"
2022-12-22 18:11:57 +00:00
// [slot] => [signature + block without execution payload]
2022-11-26 22:05:59 +00:00
BeaconBlocks = "BeaconBlock"
2023-03-05 18:28:54 +00:00
// [slot] => [attestation list (custom encoding)]
2022-12-22 18:11:57 +00:00
Attestetations = "Attestetations"
2023-10-18 21:10:53 +00:00
// [slot] => [Canonical block root]
CanonicalBlockRoots = "CanonicalBlockRoots"
// [Root (block root] => Slot
BlockRootToSlot = "BlockRootToSlot"
// [Block Root] => [State Root]
BlockRootToStateRoot = "BlockRootToStateRoot"
StateRootToBlockRoot = "StateRootToBlockRoot"
BlockRootToBlockNumber = "BlockRootToBlockNumber"
BlockRootToBlockHash = "BlockRootToBlockHash"
LastBeaconSnapshot = "LastBeaconSnapshot"
LastBeaconSnapshotKey = "LastBeaconSnapshotKey"
2023-10-18 21:10:53 +00:00
// [Block Root] => [Parent Root]
BlockRootToParentRoot = "BlockRootToParentRoot"
HighestFinalized = "HighestFinalized" // hash -> transaction/receipt lookup metadata
2023-10-18 21:10:53 +00:00
// BlockRoot => Beacon Block Header
BeaconBlockHeaders = "BeaconBlockHeaders"
2022-12-28 16:43:51 +00:00
// LightClientStore => LightClientStore object
// LightClientFinalityUpdate => latest finality update
// LightClientOptimisticUpdate => latest optimistic update
LightClient = "LightClient"
// Period (one every 27 hours) => LightClientUpdate
LightClientUpdates = "LightClientUpdates"
// Beacon historical data
// ValidatorIndex => [Field]
2023-12-18 12:54:15 +00:00
ValidatorPublicKeys = "ValidatorPublickeys"
InvertedValidatorPublicKeys = "InvertedValidatorPublickeys"
// ValidatorIndex + Slot => [Field]
ValidatorEffectiveBalance = "ValidatorEffectiveBalance"
ValidatorSlashings = "ValidatorSlashings"
ValidatorBalance = "ValidatorBalance"
StaticValidators = "StaticValidators"
StateEvents = "StateEvents"
ActiveValidatorIndicies = "ActiveValidatorIndicies"
// External data
StateRoot = "StateRoot"
BlockRoot = "BlockRoot"
// Differentiate data stored per-slot vs per-epoch
SlotData = "SlotData"
EpochData = "EpochData"
// State fields
InactivityScores = "InactivityScores"
PreviousEpochParticipation = "PreviousEpochParticipation"
CurrentEpochParticipation = "CurrentEpochParticipation"
NextSyncCommittee = "NextSyncCommittee"
CurrentSyncCommittee = "CurrentSyncCommittee"
HistoricalRoots = "HistoricalRoots"
HistoricalSummaries = "HistoricalSummaries"
CurrentEpochAttestations = "EpochAttestations"
PreviousEpochAttestations = "PreviousAttestations"
Eth1DataVotes = "Eth1DataVotes"
IntraRandaoMixes = "IntraRandaoMixes" // [validator_index+slot] => [randao_mix]
RandaoMixes = "RandaoMixes" // [validator_index+slot] => [randao_mix]
Proposers = "BlockProposers" // epoch => proposers indicies
StatesProcessingProgress = "StatesProcessingProgress"
2021-07-28 03:36:06 +00:00
)
// Keys
var (
//StorageModeTEVM - does not translate EVM to TEVM
StorageModeTEVM = []byte("smTEVM")
PruneTypeOlder = []byte("older")
PruneTypeBefore = []byte("before")
PruneHistory = []byte("pruneHistory")
PruneHistoryType = []byte("pruneHistoryType")
PruneReceipts = []byte("pruneReceipts")
PruneReceiptsType = []byte("pruneReceiptsType")
PruneTxIndex = []byte("pruneTxIndex")
PruneTxIndexType = []byte("pruneTxIndexType")
PruneCallTraces = []byte("pruneCallTraces")
PruneCallTracesType = []byte("pruneCallTracesType")
2021-07-28 03:36:06 +00:00
DBSchemaVersionKey = []byte("dbVersion")
BittorrentPeerID = "peerID"
CurrentHeadersSnapshotHash = []byte("CurrentHeadersSnapshotHash")
CurrentHeadersSnapshotBlock = []byte("CurrentHeadersSnapshotBlock")
CurrentBodiesSnapshotHash = []byte("CurrentBodiesSnapshotHash")
CurrentBodiesSnapshotBlock = []byte("CurrentBodiesSnapshotBlock")
PlainStateVersion = []byte("PlainStateVersion")
HighestFinalizedKey = []byte("HighestFinalized")
LightClientStore = []byte("LightClientStore")
LightClientFinalityUpdate = []byte("LightClientFinalityUpdate")
LightClientOptimisticUpdate = []byte("LightClientOptimisticUpdate")
StatesProcessingKey = []byte("StatesProcessing")
2021-07-28 03:36:06 +00:00
)
// ChaindataTables - list of all buckets. App will panic if some bucket is not in this list.
// This list will be sorted in `init` method.
// ChaindataTablesCfg - can be used to find index in sorted version of ChaindataTables list by name
var ChaindataTables = []string{
2023-06-11 14:12:07 +00:00
E2AccountsHistory,
E2StorageHistory,
2021-07-28 03:36:06 +00:00
Code,
ContractCode,
HeaderNumber,
BadHeaderNumber,
2021-07-28 03:36:06 +00:00
BlockBody,
Receipts,
TxLookup,
ConfigTable,
CurrentExecutionPayload,
2021-07-28 03:36:06 +00:00
DatabaseInfo,
IncarnationMap,
ContractTEVMCode,
CliqueSeparate,
CliqueLastSnapshot,
CliqueSnapshot,
SyncStageProgress,
PlainState,
PlainContractCode,
AccountChangeSet,
StorageChangeSet,
Senders,
HeadBlockKey,
HeadHeaderKey,
LastForkchoice,
2021-07-28 03:36:06 +00:00
Migrations,
LogTopicIndex,
LogAddressIndex,
CallTraceSet,
CallFromIndex,
CallToIndex,
2022-01-20 08:25:03 +00:00
CumulativeGasIndex,
CumulativeTransactionIndex,
2021-07-28 03:36:06 +00:00
Log,
Sequence,
EthTx,
NonCanonicalTxs,
2021-07-28 03:36:06 +00:00
TrieOfAccounts,
TrieOfStorage,
HashedAccounts,
HashedStorage,
HeaderCanonical,
Headers,
HeaderTD,
Epoch,
PendingEpoch,
2021-08-11 23:40:38 +00:00
Issuance,
StateAccounts,
StateStorage,
StateCode,
[erigon2] Introduce commitment files and table (#201) * Introduce commitment files and table * Introduce commitment files and table * Introduce words buffer * Move changes out of aggregator into the writer * Start calc commitment * Add commitment package * More on hex patricia * More * account decorator * More * Add test * More * More to the test * Use hex in tests * More * More * More * More * Simplified cells * Add delBitmap * More advanced MockState * More compact unfolding * Separation of hashed Keys * Sepatate downHashedKey and upHashedKey * Carry extension node through accounts * optimised row allocations * Fix encoding/decoding, add trace flag * Added account and storage into the cells * Make accountKeyLen global setting * Remove BranchNodeUpdaqte intermediate * Started on computeHash * Initial hash calculations * Fix lint * Change account encoding * Fix commitment issues * Fix lint * Fix lint * Fix lint * Trace * Small fix and tracing * Print branch hashes, fix empty * Fix * Fix * Fix * Fix * Print accountFn * Trigger accountFn * Trigger accountFn * Another fix for extension nodes * Return root hash and set trace * Print depth for computeCellHash * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Fix for storage leaves * Ineffectual deletes * Trace needUnfolding * Fix * Fix * Fix * trace deletes * trace deletes * trace deletes * trace deletes * trace deletes * not overwrite downHashedKey in updateAccount * simplify needUnfolding * simplify needUnfolding * simplify needUnfolding * simplify needUnfolding * simplify needUnfolding * propagate deletes when unfolding * remove deletes when folding * remove deletes when folding * remove upHashedKey when delete cell * remove upHashedKey when delete cell * aggregate storage changes later * remove del bit when updating account * remove del bit when updating account * remove del bit when updating account * perform delete after code update * perform delete after code update * perform delete after code update * perform delete after code update * perform delete after code update * perform delete after code update * latest update has precedence when aggregating * Revert "latest update has precedence when aggregating" This reverts commit 0234ea6c3e1a0b2e7599df7c470d4b8b8d56736a. * latest update has precedence when aggregating * Revert "latest update has precedence when aggregating" This reverts commit cfa7b75327e4d5d1236f905c3c04eb640b21838d. * Introduce FinishTx * Separate commitment separation from computation * Prevent spurious delete * Spurious deletes * Trace param * Preserve upHashedKey when unfolding * Fix * Fix * Correctly compute firstInsert * Try to fix delete + fold * Remove commented out * updateStorage to remove deleted flag * rename upHashedKey to extension, fix clear-up * Carry extension up if account plain key is present * Carry extension up if account plain key is present * Not to fail for deleteAccount * Not to fail for deleteAccount * Not to fail for deleteAccount * Print * Print * Print * Print * Print * Print * Print * Print * Copy keys before putting them into commTree * Preserve changes to AccountData Co-authored-by: Alex Sharp <alexsharp@Alexs-MacBook-Pro.local> Co-authored-by: Alexey Sharp <alexeysharp@Alexeys-iMac.local>
2022-01-12 11:21:52 +00:00
StateCommitment,
BorReceipts,
BorFinality,
BorTxLookup,
BorSeparate,
BorEvents,
BorEventNums,
BorSpans,
2023-06-11 14:12:07 +00:00
TblAccountKeys,
TblAccountVals,
TblAccountHistoryKeys,
TblAccountHistoryVals,
TblAccountIdx,
TblStorageKeys,
TblStorageVals,
TblStorageHistoryKeys,
TblStorageHistoryVals,
TblStorageIdx,
TblCodeKeys,
TblCodeVals,
TblCodeHistoryKeys,
TblCodeHistoryVals,
TblCodeIdx,
TblCommitmentKeys,
TblCommitmentVals,
TblCommitmentHistoryKeys,
TblCommitmentHistoryVals,
TblCommitmentIdx,
TblLogAddressKeys,
TblLogAddressIdx,
TblLogTopicsKeys,
TblLogTopicsIdx,
TblTracesFromKeys,
TblTracesFromIdx,
TblTracesToKeys,
TblTracesToIdx,
2022-07-04 04:56:35 +00:00
Snapshots,
MaxTxNum,
2022-07-04 04:56:35 +00:00
RAccountKeys,
RAccountIdx,
RStorageKeys,
RStorageIdx,
RCodeKeys,
RCodeIdx,
2022-09-22 16:05:02 +00:00
VerkleRoots,
VerkleTrie,
2022-12-22 18:11:57 +00:00
// Beacon stuff
2022-11-02 00:00:59 +00:00
BeaconState,
2022-11-26 22:05:59 +00:00
BeaconBlocks,
2023-10-18 21:10:53 +00:00
CanonicalBlockRoots,
BlockRootToSlot,
BlockRootToStateRoot,
StateRootToBlockRoot,
BlockRootToParentRoot,
BeaconBlockHeaders,
HighestFinalized,
2022-12-22 18:11:57 +00:00
Attestetations,
LightClient,
LightClientUpdates,
BlockRootToBlockHash,
BlockRootToBlockNumber,
LastBeaconSnapshot,
// State Reconstitution
ValidatorPublicKeys,
2023-12-18 12:54:15 +00:00
InvertedValidatorPublicKeys,
ValidatorEffectiveBalance,
ValidatorBalance,
ValidatorSlashings,
StaticValidators,
StateEvents,
// Other stuff (related to state reconstitution)
BlockRoot,
StateRoot,
SlotData,
EpochData,
RandaoMixes,
Proposers,
StatesProcessingProgress,
PreviousEpochParticipation,
CurrentEpochParticipation,
InactivityScores,
NextSyncCommittee,
CurrentSyncCommittee,
HistoricalRoots,
HistoricalSummaries,
CurrentEpochAttestations,
PreviousEpochAttestations,
Eth1DataVotes,
IntraRandaoMixes,
ActiveValidatorIndicies,
2021-07-28 03:36:06 +00:00
}
2021-08-13 05:23:14 +00:00
const (
2021-08-30 03:07:16 +00:00
RecentLocalTransaction = "RecentLocalTransaction" // sequence_u64 -> tx_hash
PoolTransaction = "PoolTransaction" // txHash -> sender_id_u64+tx_rlp
2021-08-30 03:07:16 +00:00
PoolInfo = "PoolInfo" // option_key -> option_value
2021-08-13 05:23:14 +00:00
)
var TxPoolTables = []string{
2021-08-22 10:06:38 +00:00
RecentLocalTransaction,
2021-08-30 03:07:16 +00:00
PoolTransaction,
2021-08-22 10:06:38 +00:00
PoolInfo,
2021-08-13 05:23:14 +00:00
}
2021-07-28 03:36:06 +00:00
var SentryTables = []string{}
var DownloaderTables = []string{
BittorrentCompletion,
BittorrentInfo,
}
var ReconTables = []string{
PlainStateR,
PlainStateD,
CodeR,
CodeD,
PlainContractR,
PlainContractD,
}
2021-07-28 03:36:06 +00:00
// ChaindataDeprecatedTables - list of buckets which can be programmatically deleted - for example after migration
var ChaindataDeprecatedTables = []string{
Clique,
TransitionBlockKey,
2021-07-28 03:36:06 +00:00
}
type CmpFunc func(k1, k2, v1, v2 []byte) int
type TableCfg map[string]TableCfgItem
type Bucket string
type DBI uint
type TableFlags uint
const (
Default TableFlags = 0x00
ReverseKey TableFlags = 0x02
DupSort TableFlags = 0x04
IntegerKey TableFlags = 0x08
IntegerDup TableFlags = 0x20
ReverseDup TableFlags = 0x40
)
type TableCfgItem struct {
Flags TableFlags
// AutoDupSortKeysConversion - enables some keys transformation - to change db layout without changing app code.
// Use it wisely - it helps to do experiments with DB format faster, but better reduce amount of Magic in app.
// If good DB format found, push app code to accept this format and then disable this property.
AutoDupSortKeysConversion bool
IsDeprecated bool
DBI DBI
// DupFromLen - if user provide key of this length, then next transformation applied:
// v = append(k[DupToLen:], v...)
// k = k[:DupToLen]
// And opposite at retrieval
// Works only if AutoDupSortKeysConversion enabled
DupFromLen int
DupToLen int
}
var ChaindataTablesCfg = TableCfg{
HashedStorage: {
Flags: DupSort,
AutoDupSortKeysConversion: true,
DupFromLen: 72,
DupToLen: 40,
},
AccountChangeSet: {Flags: DupSort},
StorageChangeSet: {Flags: DupSort},
2021-07-28 03:36:06 +00:00
PlainState: {
Flags: DupSort,
AutoDupSortKeysConversion: true,
DupFromLen: 60,
DupToLen: 28,
},
CallTraceSet: {Flags: DupSort},
2023-06-11 14:12:07 +00:00
TblAccountKeys: {Flags: DupSort},
TblAccountHistoryKeys: {Flags: DupSort},
TblAccountHistoryVals: {Flags: DupSort},
TblAccountIdx: {Flags: DupSort},
TblStorageKeys: {Flags: DupSort},
TblStorageHistoryKeys: {Flags: DupSort},
TblStorageHistoryVals: {Flags: DupSort},
TblStorageIdx: {Flags: DupSort},
TblCodeKeys: {Flags: DupSort},
TblCodeHistoryKeys: {Flags: DupSort},
TblCodeIdx: {Flags: DupSort},
TblCommitmentKeys: {Flags: DupSort},
TblCommitmentHistoryKeys: {Flags: DupSort},
TblCommitmentIdx: {Flags: DupSort},
TblLogAddressKeys: {Flags: DupSort},
TblLogAddressIdx: {Flags: DupSort},
TblLogTopicsKeys: {Flags: DupSort},
TblLogTopicsIdx: {Flags: DupSort},
TblTracesFromKeys: {Flags: DupSort},
TblTracesFromIdx: {Flags: DupSort},
TblTracesToKeys: {Flags: DupSort},
TblTracesToIdx: {Flags: DupSort},
RAccountKeys: {Flags: DupSort},
RAccountIdx: {Flags: DupSort},
RStorageKeys: {Flags: DupSort},
RStorageIdx: {Flags: DupSort},
RCodeKeys: {Flags: DupSort},
RCodeIdx: {Flags: DupSort},
2021-07-28 03:36:06 +00:00
}
var BorTablesCfg = TableCfg{
BorReceipts: {Flags: DupSort},
BorFinality: {Flags: DupSort},
BorTxLookup: {Flags: DupSort},
BorEvents: {Flags: DupSort},
BorEventNums: {Flags: DupSort},
BorSpans: {Flags: DupSort},
}
2021-08-17 03:10:54 +00:00
var TxpoolTablesCfg = TableCfg{}
2021-10-28 11:45:18 +00:00
var SentryTablesCfg = TableCfg{}
var DownloaderTablesCfg = TableCfg{}
var ReconTablesCfg = TableCfg{
PlainStateD: {Flags: DupSort},
CodeD: {Flags: DupSort},
PlainContractD: {Flags: DupSort},
}
2021-08-17 03:10:54 +00:00
func TablesCfgByLabel(label Label) TableCfg {
switch label {
case ChainDB:
return ChaindataTablesCfg
case TxPoolDB:
return TxpoolTablesCfg
case SentryDB:
return SentryTablesCfg
case DownloaderDB:
return DownloaderTablesCfg
default:
panic(fmt.Sprintf("unexpected label: %s", label))
}
}
2021-07-28 03:36:06 +00:00
func sortBuckets() {
sort.SliceStable(ChaindataTables, func(i, j int) bool {
return strings.Compare(ChaindataTables[i], ChaindataTables[j]) < 0
})
}
func init() {
reinit()
}
func reinit() {
sortBuckets()
for _, name := range ChaindataTables {
_, ok := ChaindataTablesCfg[name]
if !ok {
ChaindataTablesCfg[name] = TableCfgItem{}
}
}
for _, name := range ChaindataDeprecatedTables {
_, ok := ChaindataTablesCfg[name]
if !ok {
ChaindataTablesCfg[name] = TableCfgItem{}
}
tmp := ChaindataTablesCfg[name]
tmp.IsDeprecated = true
ChaindataTablesCfg[name] = tmp
}
2021-08-17 03:10:54 +00:00
for _, name := range TxPoolTables {
_, ok := TxpoolTablesCfg[name]
if !ok {
TxpoolTablesCfg[name] = TableCfgItem{}
}
}
2021-10-28 11:45:18 +00:00
for _, name := range SentryTables {
_, ok := SentryTablesCfg[name]
if !ok {
SentryTablesCfg[name] = TableCfgItem{}
}
}
for _, name := range DownloaderTables {
_, ok := DownloaderTablesCfg[name]
if !ok {
DownloaderTablesCfg[name] = TableCfgItem{}
}
}
for _, name := range ReconTables {
_, ok := ReconTablesCfg[name]
if !ok {
ReconTablesCfg[name] = TableCfgItem{}
}
}
2021-07-28 03:36:06 +00:00
}
2023-06-11 14:12:07 +00:00
// Temporal
const (
AccountsDomain Domain = "AccountsDomain"
StorageDomain Domain = "StorageDomain"
CodeDomain Domain = "CodeDomain"
)
const (
AccountsHistory History = "AccountsHistory"
StorageHistory History = "StorageHistory"
CodeHistory History = "CodeHistory"
)
const (
AccountsHistoryIdx InvertedIdx = "AccountsHistoryIdx"
StorageHistoryIdx InvertedIdx = "StorageHistoryIdx"
CodeHistoryIdx InvertedIdx = "CodeHistoryIdx"
LogTopicIdx InvertedIdx = "LogTopicIdx"
LogAddrIdx InvertedIdx = "LogAddrIdx"
TracesFromIdx InvertedIdx = "TracesFromIdx"
TracesToIdx InvertedIdx = "TracesToIdx"
)