2022-11-01 15:07:44 +00:00
|
|
|
|
# Nimbus
|
|
|
|
|
# Copyright (c) 2021 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.
|
|
|
|
|
|
2023-01-30 22:10:23 +00:00
|
|
|
|
{.push raises: [].}
|
2022-11-01 15:07:44 +00:00
|
|
|
|
|
2023-03-22 20:11:49 +00:00
|
|
|
|
import
|
2023-04-04 14:36:18 +01:00
|
|
|
|
std/sets,
|
2023-03-25 10:44:48 +00:00
|
|
|
|
eth/[common, trie/nibbles]
|
2023-03-22 20:11:49 +00:00
|
|
|
|
|
2022-11-01 15:07:44 +00:00
|
|
|
|
const
|
2023-03-22 20:11:49 +00:00
|
|
|
|
EmptyBlob* = seq[byte].default
|
|
|
|
|
## Useful shortcut
|
|
|
|
|
|
2023-04-04 14:36:18 +01:00
|
|
|
|
EmptyBlobSet* = HashSet[Blob].default
|
|
|
|
|
## Useful shortcut
|
|
|
|
|
|
2023-03-25 10:44:48 +00:00
|
|
|
|
EmptyBlobSeq* = seq[Blob].default
|
|
|
|
|
## Useful shortcut
|
|
|
|
|
|
2023-03-22 20:11:49 +00:00
|
|
|
|
EmptyNibbleSeq* = EmptyBlob.initNibbleRange
|
|
|
|
|
## Useful shortcut
|
|
|
|
|
|
|
|
|
|
# ---------
|
|
|
|
|
|
2022-12-12 22:00:24 +00:00
|
|
|
|
pivotTableLruEntriesMax* = 50
|
|
|
|
|
## Max depth of pivot table. On overflow, the oldest one will be removed.
|
|
|
|
|
|
2022-11-01 15:07:44 +00:00
|
|
|
|
pivotBlockDistanceMin* = 128
|
|
|
|
|
## The minimal depth of two block headers needed to activate a new state
|
|
|
|
|
## root pivot.
|
|
|
|
|
##
|
|
|
|
|
## Effects on assembling the state via `snap/1` protocol:
|
|
|
|
|
##
|
|
|
|
|
## * A small value of this constant increases the propensity to update the
|
|
|
|
|
## pivot header more often. This is so because each new peer negoiates a
|
|
|
|
|
## pivot block number at least the current one.
|
|
|
|
|
##
|
|
|
|
|
## * A large value keeps the current pivot more stable but some experiments
|
|
|
|
|
## suggest that the `snap/1` protocol is answered only for later block
|
|
|
|
|
## numbers (aka pivot blocks.) So a large value tends to keep the pivot
|
|
|
|
|
## farther away from the chain head.
|
|
|
|
|
##
|
|
|
|
|
## Note that 128 is the magic distance for snapshots used by *Geth*.
|
|
|
|
|
|
|
|
|
|
# --------------
|
|
|
|
|
|
2022-12-24 09:54:18 +00:00
|
|
|
|
fetchRequestBytesLimit* = 2 * 1024 * 1024
|
|
|
|
|
## Soft bytes limit to request in `snap/1` protocol calls.
|
2022-11-01 15:07:44 +00:00
|
|
|
|
|
2022-12-24 09:54:18 +00:00
|
|
|
|
fetchRequestTrieNodesMax* = 1024
|
|
|
|
|
## Informal maximal number of trie nodes to fetch at once in `snap/1`
|
2022-11-25 14:56:42 +00:00
|
|
|
|
## protocol calls. This is not an official limit but found with several
|
|
|
|
|
## implementations (e.g. Geth.)
|
|
|
|
|
##
|
2022-12-24 09:54:18 +00:00
|
|
|
|
## Resticting the fetch list length early allows to better parallelise
|
2022-11-25 14:56:42 +00:00
|
|
|
|
## healing.
|
|
|
|
|
|
2022-12-24 09:54:18 +00:00
|
|
|
|
fetchRequestStorageSlotsMax* = 2 * 1024
|
|
|
|
|
## Maximal number of storage tries to fetch with a single request message.
|
2022-11-25 14:56:42 +00:00
|
|
|
|
|
2022-12-24 09:54:18 +00:00
|
|
|
|
# --------------
|
|
|
|
|
|
2023-04-21 22:11:04 +01:00
|
|
|
|
fetchRequestContractsMax* = 1024
|
|
|
|
|
## Maximal number of contract codes fetch with a single request message.
|
|
|
|
|
|
|
|
|
|
# --------------
|
|
|
|
|
|
|
|
|
|
saveAccountsProcessedChunksMax* = 1000
|
2022-11-25 14:56:42 +00:00
|
|
|
|
## Recovery data are stored if the processed ranges list contains no more
|
2022-12-12 22:00:24 +00:00
|
|
|
|
## than this many range *chunks*.
|
2022-11-16 23:51:06 +00:00
|
|
|
|
##
|
2022-12-12 22:00:24 +00:00
|
|
|
|
## If the range set is too much fragmented, no data will be saved and
|
|
|
|
|
## restart has to perform from scratch or an earlier checkpoint.
|
2022-11-01 15:07:44 +00:00
|
|
|
|
|
2023-04-21 22:11:04 +01:00
|
|
|
|
saveStorageSlotsMax* = 20_000
|
2022-11-25 14:56:42 +00:00
|
|
|
|
## Recovery data are stored if the oustanding storage slots to process do
|
|
|
|
|
## not amount to more than this many entries.
|
2022-11-01 15:07:44 +00:00
|
|
|
|
##
|
2022-11-25 14:56:42 +00:00
|
|
|
|
## If there are too many dangling nodes, no data will be saved and restart
|
2022-12-12 22:00:24 +00:00
|
|
|
|
## has to perform from scratch or an earlier checkpoint.
|
2022-11-01 15:07:44 +00:00
|
|
|
|
|
2023-04-21 22:11:04 +01:00
|
|
|
|
saveContactsMax* = 10_000
|
|
|
|
|
## Similar to `saveStorageSlotsMax`
|
|
|
|
|
|
2023-04-04 14:36:18 +01:00
|
|
|
|
# --------------
|
|
|
|
|
|
|
|
|
|
storageSlotsFetchFailedFullMax* = fetchRequestStorageSlotsMax + 100
|
|
|
|
|
## Maximal number of failures when fetching full range storage slots.
|
|
|
|
|
## These failed slot ranges are only called for once in the same cycle.
|
|
|
|
|
|
|
|
|
|
storageSlotsFetchFailedPartialMax* = 300
|
|
|
|
|
## Ditto for partial range storage slots.
|
2022-11-01 15:07:44 +00:00
|
|
|
|
|
2022-12-24 09:54:18 +00:00
|
|
|
|
storageSlotsTrieInheritPerusalMax* = 30_000
|
|
|
|
|
## Maximal number of nodes to visit in order to find out whether this
|
|
|
|
|
## storage slots trie is complete. This allows to *inherit* the full trie
|
|
|
|
|
## for an existing root node if the trie is small enough.
|
2022-11-16 23:51:06 +00:00
|
|
|
|
|
2022-12-24 09:54:18 +00:00
|
|
|
|
storageSlotsQuPrioThresh* = 5_000
|
2022-11-08 18:56:04 +00:00
|
|
|
|
## For a new worker, prioritise processing the storage slots queue over
|
|
|
|
|
## processing accounts if the queue has more than this many items.
|
2022-11-16 23:51:06 +00:00
|
|
|
|
##
|
2022-11-08 18:56:04 +00:00
|
|
|
|
## For a running worker processing accounts, stop processing accounts
|
|
|
|
|
## and switch to processing the storage slots queue if the queue has
|
|
|
|
|
## more than this many items.
|
2022-11-16 23:51:06 +00:00
|
|
|
|
|
2022-11-25 14:56:42 +00:00
|
|
|
|
# --------------
|
2022-11-16 23:51:06 +00:00
|
|
|
|
|
2023-04-21 22:11:04 +01:00
|
|
|
|
contractsQuPrioThresh* = 2_000
|
|
|
|
|
## Similar to `storageSlotsQuPrioThresh`
|
|
|
|
|
|
|
|
|
|
# --------------
|
|
|
|
|
|
2023-04-24 21:24:07 +01:00
|
|
|
|
healAccountsCoverageTrigger* = 1.01
|
2022-11-01 15:07:44 +00:00
|
|
|
|
## Apply accounts healing if the global snap download coverage factor
|
|
|
|
|
## exceeds this setting. The global coverage factor is derived by merging
|
|
|
|
|
## all account ranges retrieved for all pivot state roots (see
|
2022-12-24 09:54:18 +00:00
|
|
|
|
## `coveredAccounts` in the object `CtxData`.) Note that a coverage factor
|
|
|
|
|
## greater than 100% is not exact but rather a lower bound estimate.
|
|
|
|
|
|
|
|
|
|
healAccountsInspectionPlanBLevel* = 4
|
|
|
|
|
## Search this level deep for missing nodes if `hexaryEnvelopeDecompose()`
|
|
|
|
|
## only produces existing nodes.
|
2022-11-28 09:03:23 +00:00
|
|
|
|
|
2023-03-25 10:44:48 +00:00
|
|
|
|
healAccountsInspectionPlanBRetryMax* = 2
|
2023-04-04 14:36:18 +01:00
|
|
|
|
## Retry inspection with depth level argument starting at
|
|
|
|
|
## `healAccountsInspectionPlanBLevel-1` and counting down at most this
|
|
|
|
|
## many times until there is at least one dangling node found and the
|
|
|
|
|
## depth level argument remains positive. The cumulative depth of the
|
|
|
|
|
## iterated seach is
|
|
|
|
|
## ::
|
|
|
|
|
## b 1
|
|
|
|
|
## Σ ν = --- (b - a + 1) (a + b)
|
|
|
|
|
## a 2
|
|
|
|
|
## for
|
|
|
|
|
## ::
|
|
|
|
|
## b = healAccountsInspectionPlanBLevel
|
|
|
|
|
## a = b - healAccountsInspectionPlanBRetryMax
|
|
|
|
|
##
|
2022-11-16 23:51:06 +00:00
|
|
|
|
|
2023-03-25 10:44:48 +00:00
|
|
|
|
healAccountsInspectionPlanBRetryNapMSecs* = 2
|
|
|
|
|
## Sleep beween inspection retrys to allow thread switch. If this constant
|
|
|
|
|
## is set `0`, `1`ns wait is used.
|
2022-11-16 23:51:06 +00:00
|
|
|
|
|
2023-04-04 14:36:18 +01:00
|
|
|
|
# --------------
|
2022-11-01 15:07:44 +00:00
|
|
|
|
|
2023-04-04 14:36:18 +01:00
|
|
|
|
healStorageSlotsInspectionPlanBLevel* = 5
|
2022-12-24 09:54:18 +00:00
|
|
|
|
## Similar to `healAccountsInspectionPlanBLevel`
|
2022-11-16 23:51:06 +00:00
|
|
|
|
|
2023-04-04 14:36:18 +01:00
|
|
|
|
healStorageSlotsInspectionPlanBRetryMax* = 99 # 5 + 4 + .. + 1 => 15
|
2023-03-25 10:44:48 +00:00
|
|
|
|
## Similar to `healAccountsInspectionPlanBRetryMax`
|
|
|
|
|
|
|
|
|
|
healStorageSlotsInspectionPlanBRetryNapMSecs* = 2
|
|
|
|
|
## Similar to `healAccountsInspectionPlanBRetryNapMSecs`
|
|
|
|
|
|
2022-11-16 23:51:06 +00:00
|
|
|
|
healStorageSlotsBatchMax* = 32
|
2022-11-01 15:07:44 +00:00
|
|
|
|
## Maximal number of storage tries to to heal in a single batch run. Only
|
|
|
|
|
## this many items will be removed from the batch queue. These items will
|
|
|
|
|
## then be processed one by one.
|
|
|
|
|
|
2023-04-04 14:36:18 +01:00
|
|
|
|
healStorageSlotsFailedMax* = 300
|
|
|
|
|
## Ditto for partial range storage slots.
|
|
|
|
|
|
2022-11-01 15:07:44 +00:00
|
|
|
|
# --------------
|
|
|
|
|
|
2022-11-08 18:56:04 +00:00
|
|
|
|
comErrorsTimeoutMax* = 3
|
2022-11-01 15:07:44 +00:00
|
|
|
|
## Maximal number of non-resonses accepted in a row. If there are more than
|
|
|
|
|
## `comErrorsTimeoutMax` consecutive errors, the worker will be degraded
|
|
|
|
|
## as zombie.
|
|
|
|
|
|
|
|
|
|
comErrorsTimeoutSleepMSecs* = 5000
|
|
|
|
|
## Wait/suspend for this many seconds after a timeout error if there are
|
|
|
|
|
## not more than `comErrorsTimeoutMax` errors in a row (maybe some other
|
|
|
|
|
## network or no-data errors mixed in.) Set 0 to disable.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
comErrorsNetworkMax* = 5
|
|
|
|
|
## Similar to `comErrorsTimeoutMax` but for network errors.
|
|
|
|
|
|
|
|
|
|
comErrorsNetworkSleepMSecs* = 5000
|
|
|
|
|
## Similar to `comErrorsTimeoutSleepSecs` but for network errors.
|
|
|
|
|
## Set 0 to disable.
|
|
|
|
|
|
|
|
|
|
comErrorsNoDataMax* = 3
|
|
|
|
|
## Similar to `comErrorsTimeoutMax` but for missing data errors.
|
|
|
|
|
|
|
|
|
|
comErrorsNoDataSleepMSecs* = 0
|
|
|
|
|
## Similar to `comErrorsTimeoutSleepSecs` but for missing data errors.
|
|
|
|
|
## Set 0 to disable.
|
|
|
|
|
|
|
|
|
|
static:
|
2023-04-21 22:11:04 +01:00
|
|
|
|
doAssert storageSlotsQuPrioThresh < saveStorageSlotsMax
|
|
|
|
|
doAssert contractsQuPrioThresh < saveContactsMax
|
2023-04-04 14:36:18 +01:00
|
|
|
|
doAssert 0 <= storageSlotsFetchFailedFullMax
|
|
|
|
|
doAssert 0 <= storageSlotsFetchFailedPartialMax
|
2022-11-01 15:07:44 +00:00
|
|
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
# End
|
|
|
|
|
# ------------------------------------------------------------------------------
|