database state storage benchmarking via ncli_db (#2312)

* database state storage benchmarking via ncli_db

* more cleanups from immutable validator state branch

* unexport some eth2_network constants and remove unused variables/templates

* make two PeerScore constants public
This commit is contained in:
tersec 2021-02-15 17:40:00 +01:00 committed by GitHub
parent 946608b572
commit 5cab17dc1a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 55 additions and 55 deletions

View File

@ -2,11 +2,11 @@
import import
typetraits, tables, typetraits, tables,
stew/[results, objects, endians2, io2], stew/[endians2, io2, objects, results],
serialization, chronicles, snappy, serialization, chronicles, snappy,
eth/db/[kvstore, kvstore_sqlite3], eth/db/[kvstore, kvstore_sqlite3],
./network_metadata, ./network_metadata,
./spec/[datatypes, digest, crypto, state_transition], ./spec/[crypto, datatypes, digest, state_transition],
./ssz/[ssz_serialization, merkleization], ./ssz/[ssz_serialization, merkleization],
merkle_minimal, filepath merkle_minimal, filepath
@ -235,10 +235,8 @@ proc init*(T: type BeaconChainDB,
if sqliteStore.exec("DROP TABLE IF EXISTS deposits;").isErr: if sqliteStore.exec("DROP TABLE IF EXISTS deposits;").isErr:
debug "Failed to drop the deposits table" debug "Failed to drop the deposits table"
var var genesisDepositsSeq =
validatorKeyToIndex = initTable[ValidatorPubKey, ValidatorIndex]() DbSeq[DepositData].init(sqliteStore, "genesis_deposits")
genesisDepositsSeq = DbSeq[DepositData].init(sqliteStore, "genesis_deposits")
T(backend: kvStore sqliteStore, T(backend: kvStore sqliteStore,
preset: preset, preset: preset,

View File

@ -210,9 +210,6 @@ const
clientId* = "Nimbus beacon node " & fullVersionStr clientId* = "Nimbus beacon node " & fullVersionStr
nodeMetadataFilename = "node-metadata.json" nodeMetadataFilename = "node-metadata.json"
TCP = net.Protocol.IPPROTO_TCP
HandshakeTimeout = FaultOrError
NewPeerScore* = 200 NewPeerScore* = 200
## Score which will be assigned to new connected Peer ## Score which will be assigned to new connected Peer
PeerScoreLowLimit* = 0 PeerScoreLowLimit* = 0
@ -221,34 +218,29 @@ const
## Max value of peer's score ## Max value of peer's score
PeerScoreInvalidRequest* = -500 PeerScoreInvalidRequest* = -500
## This peer is sending malformed or nonsensical data ## This peer is sending malformed or nonsensical data
PeerScoreFlooder* = -250
## This peer is sending too many expensive requests
ConcurrentConnections* = 10 ConcurrentConnections = 10
## Maximum number of active concurrent connection requests. ## Maximum number of active concurrent connection requests.
SeenTableTimeTimeout* = SeenTableTimeTimeout =
when not defined(local_testnet): 5.minutes else: 10.seconds when not defined(local_testnet): 5.minutes else: 10.seconds
## Seen period of time for timeout connections ## Seen period of time for timeout connections
SeenTableTimeDeadPeer* = SeenTableTimeDeadPeer =
when not defined(local_testnet): 5.minutes else: 10.seconds when not defined(local_testnet): 5.minutes else: 10.seconds
## Period of time for dead peers. ## Period of time for dead peers.
SeenTableTimeIrrelevantNetwork* = 24.hours SeenTableTimeIrrelevantNetwork = 24.hours
## Period of time for `IrrelevantNetwork` error reason. ## Period of time for `IrrelevantNetwork` error reason.
SeenTableTimeClientShutDown* = 10.minutes SeenTableTimeClientShutDown = 10.minutes
## Period of time for `ClientShutDown` error reason. ## Period of time for `ClientShutDown` error reason.
SeenTableTimeFaultOrError* = 10.minutes SeenTableTimeFaultOrError = 10.minutes
## Period of time for `FaultOnError` error reason. ## Period of time for `FaultOnError` error reason.
SeenTablePenaltyError* = 60.minutes SeenTablePenaltyError = 60.minutes
## Period of time for peers which score below or equal to zero. ## Period of time for peers which score below or equal to zero.
SeenTableTimeReconnect* = 1.minutes SeenTableTimeReconnect = 1.minutes
## Minimal time between disconnection and reconnection attempt ## Minimal time between disconnection and reconnection attempt
ResolvePeerTimeout* = 1.minutes
## Maximum time allowed for peer resolve process.
template neterr(kindParam: Eth2NetworkingErrorKind): auto = template neterr(kindParam: Eth2NetworkingErrorKind): auto =
err(type(result), Eth2NetworkingError(kind: kindParam)) err(type(result), Eth2NetworkingError(kind: kindParam))

View File

@ -1368,7 +1368,7 @@ proc handleValidatorExitCommand(config: BeaconNodeConf) {.async.} =
fatal "Failed to connect to the beacon node RPC service", err = err.msg fatal "Failed to connect to the beacon node RPC service", err = err.msg
quit 1 quit 1
let (validator, validatorIdx, status, balance) = try: let (validator, validatorIdx, _, _) = try:
await rpcClient.get_v1_beacon_states_stateId_validators_validatorId( await rpcClient.get_v1_beacon_states_stateId_validators_validatorId(
"head", config.exitedValidator) "head", config.exitedValidator)
except CatchableError as err: except CatchableError as err:
@ -1431,7 +1431,7 @@ proc handleValidatorExitCommand(config: BeaconNodeConf) {.async.} =
try: try:
stdout.write prompt, ": " stdout.write prompt, ": "
stdin.readLine() stdin.readLine()
except IOError as err: except IOError:
fatal "Failed to read user input from stdin" fatal "Failed to read user input from stdin"
quit 1 quit 1

View File

@ -1,5 +1,5 @@
# beacon_chain # beacon_chain
# Copyright (c) 2018-2020 Status Research & Development GmbH # Copyright (c) 2018-2021 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
@ -31,8 +31,6 @@ import
logScope: topics = "vc" logScope: topics = "vc"
template sourceDir: string = currentSourcePath.rsplit(DirSep, 1)[0]
type type
ValidatorClient = ref object ValidatorClient = ref object
config: ValidatorClientConf config: ValidatorClientConf

View File

@ -1,4 +1,4 @@
# Copyright (c) 2018-2020 Status Research & Development GmbH # Copyright (c) 2018-2021 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
@ -16,7 +16,7 @@ import
../eth1_monitor, ../validator_duties, ../eth1_monitor, ../validator_duties,
../spec/[digest, datatypes, presets], ../spec/[digest, datatypes, presets],
libp2p/protocols/pubsub/[gossipsub, pubsubpeer] libp2p/protocols/pubsub/pubsubpeer
logScope: topics = "nimbusapi" logScope: topics = "nimbusapi"

View File

@ -656,6 +656,11 @@ type
DoppelgangerProtection* = object DoppelgangerProtection* = object
broadcastStartEpoch*: Epoch broadcastStartEpoch*: Epoch
func getImmutableValidatorData*(validator: Validator): ImmutableValidatorData =
ImmutableValidatorData(
pubkey: validator.pubkey,
withdrawal_credentials: validator.withdrawal_credentials)
func getDepositMessage*(depositData: DepositData): DepositMessage = func getDepositMessage*(depositData: DepositData): DepositMessage =
result.pubkey = depositData.pubkey result.pubkey = depositData.pubkey
result.amount = depositData.amount result.amount = depositData.amount

View File

@ -1,5 +1,5 @@
# beacon_chain # beacon_chain
# Copyright (c) 2020 Status Research & Development GmbH # Copyright (c) 2020-2021 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
@ -26,11 +26,6 @@ func applyModIncrement[T, U](
ha[indexSlot mod U.uint64] = item ha[indexSlot mod U.uint64] = item
indexSlot += 1 indexSlot += 1
func getImmutableValidatorData*(validator: Validator): ImmutableValidatorData =
ImmutableValidatorData(
pubkey: validator.pubkey,
withdrawal_credentials: validator.withdrawal_credentials)
func applyValidatorIdentities( func applyValidatorIdentities(
validators: var HashList[Validator, Limit VALIDATOR_REGISTRY_LIMIT], validators: var HashList[Validator, Limit VALIDATOR_REGISTRY_LIMIT],
hl: auto) = hl: auto) =
@ -39,20 +34,6 @@ func applyValidatorIdentities(
pubkey: item.pubkey, pubkey: item.pubkey,
withdrawal_credentials: item.withdrawal_credentials) withdrawal_credentials: item.withdrawal_credentials)
func getValidatorStatus(validator: Validator): ValidatorStatus =
ValidatorStatus(
effective_balance: validator.effective_balance,
slashed: validator.slashed,
activation_eligibility_epoch: validator.activation_eligibility_epoch,
activation_epoch: validator.activation_epoch,
exit_epoch: validator.exit_epoch,
withdrawable_epoch: validator.withdrawable_epoch)
func getValidatorStatuses(state: BeaconState):
List[ValidatorStatus, Limit VALIDATOR_REGISTRY_LIMIT] =
for validator in state.validators:
result.add getValidatorStatus(validator)
func setValidatorStatuses( func setValidatorStatuses(
validators: var HashList[Validator, Limit VALIDATOR_REGISTRY_LIMIT], validators: var HashList[Validator, Limit VALIDATOR_REGISTRY_LIMIT],
hl: List[ValidatorStatus, Limit VALIDATOR_REGISTRY_LIMIT]) = hl: List[ValidatorStatus, Limit VALIDATOR_REGISTRY_LIMIT]) =
@ -115,6 +96,21 @@ func replaceOrAddDecodeEth1Votes[T, U](
for item in votes1: for item in votes1:
votes0.add item votes0.add item
func getMutableValidatorStatus(validator: Validator): ValidatorStatus =
ValidatorStatus(
effective_balance: validator.effective_balance,
slashed: validator.slashed,
activation_eligibility_epoch: validator.activation_eligibility_epoch,
activation_epoch: validator.activation_epoch,
exit_epoch: validator.exit_epoch,
withdrawable_epoch: validator.withdrawable_epoch)
func getMutableValidatorStatuses(state: BeaconState):
List[ValidatorStatus, Limit VALIDATOR_REGISTRY_LIMIT] =
# use mapIt + .init(foo)?
for validator in state.validators:
result.add getMutableValidatorStatus(validator)
func diffStates*(state0, state1: BeaconState): BeaconStateDiff = func diffStates*(state0, state1: BeaconState): BeaconStateDiff =
doAssert state1.slot > state0.slot doAssert state1.slot > state0.slot
doAssert state0.slot.isEpoch doAssert state0.slot.isEpoch
@ -149,7 +145,7 @@ func diffStates*(state0, state1: BeaconState): BeaconStateDiff =
eth1_data_votes: eth1_data_votes, eth1_data_votes: eth1_data_votes,
eth1_deposit_index: state1.eth1_deposit_index, eth1_deposit_index: state1.eth1_deposit_index,
validatorStatuses: getValidatorStatuses(state1), validatorStatuses: getMutableValidatorStatuses(state1),
balances: deltaEncodeBalances(state1.balances), balances: deltaEncodeBalances(state1.balances),
# RANDAO mixes gets updated every block, in place # RANDAO mixes gets updated every block, in place

View File

@ -3,7 +3,7 @@ import
chronicles, confutils, stew/byteutils, eth/db/kvstore_sqlite3, chronicles, confutils, stew/byteutils, eth/db/kvstore_sqlite3,
../beacon_chain/network_metadata, ../beacon_chain/network_metadata,
../beacon_chain/[beacon_chain_db, extras], ../beacon_chain/[beacon_chain_db, extras],
../beacon_chain/block_pools/[chain_dag], ../beacon_chain/block_pools/chain_dag,
../beacon_chain/spec/[crypto, datatypes, digest, helpers, ../beacon_chain/spec/[crypto, datatypes, digest, helpers,
state_transition, presets], state_transition, presets],
../beacon_chain/[ssz, sszdump], ../beacon_chain/[ssz, sszdump],
@ -16,7 +16,7 @@ type Timers = enum
tAdvanceSlot = "Advance slot, non-epoch" tAdvanceSlot = "Advance slot, non-epoch"
tAdvanceEpoch = "Advance slot, epoch" tAdvanceEpoch = "Advance slot, epoch"
tApplyBlock = "Apply block, no slot processing" tApplyBlock = "Apply block, no slot processing"
tDbStore = "Database block store" tDbStore = "Database store"
type type
DbCmd* = enum DbCmd* = enum
@ -50,6 +50,9 @@ type
storeBlocks* {. storeBlocks* {.
defaultValue: false defaultValue: false
desc: "Store each read block back into a separate database".}: bool desc: "Store each read block back into a separate database".}: bool
storeStates* {.
defaultValue: false
desc: "Store a state each epoch into a separate database".}: bool
printTimes* {. printTimes* {.
defaultValue: true defaultValue: true
desc: "Print csv of block processing time".}: bool desc: "Print csv of block processing time".}: bool
@ -93,7 +96,9 @@ proc cmdBench(conf: DbConf, runtimePreset: RuntimePreset) =
let let
db = BeaconChainDB.init(runtimePreset, conf.databaseDir.string) db = BeaconChainDB.init(runtimePreset, conf.databaseDir.string)
dbBenchmark = BeaconChainDB.init(runtimePreset, "benchmark") dbBenchmark = BeaconChainDB.init(runtimePreset, "benchmark")
defer: db.close() defer:
db.close()
dbBenchmark.close()
if not ChainDAGRef.isInitialized(db): if not ChainDAGRef.isInitialized(db):
echo "Database not initialized" echo "Database not initialized"
@ -152,6 +157,12 @@ proc cmdBench(conf: DbConf, runtimePreset: RuntimePreset) =
withTimer(timers[tDbStore]): withTimer(timers[tDbStore]):
dbBenchmark.putBlock(b) dbBenchmark.putBlock(b)
if conf.storeStates:
withTimer(timers[tDbStore]):
if state[].data.slot mod SLOTS_PER_EPOCH == 0:
dbBenchmark.putState(state[].root, state[].data)
dbBenchmark.checkpoint()
printTimers(false, timers) printTimers(false, timers)
proc cmdDumpState(conf: DbConf, preset: RuntimePreset) = proc cmdDumpState(conf: DbConf, preset: RuntimePreset) =

View File

@ -1,5 +1,5 @@
# beacon_chain # beacon_chain
# Copyright (c) 2019-2020 Status Research & Development GmbH # Copyright (c) 2019-2021 Status Research & Development GmbH
# Licensed and distributed under either of # Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT). # * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
@ -42,7 +42,7 @@ cli do(slots = SLOTS_PER_EPOCH * 6,
validate = true): validate = true):
let let
flags = if validate: {} else: {skipBlsValidation} flags = if validate: {} else: {skipBlsValidation}
(state, depositContractState) = loadGenesis(validators, validate) (state, _) = loadGenesis(validators, validate)
genesisBlock = get_initial_beacon_block(state.data) genesisBlock = get_initial_beacon_block(state.data)
echo "Starting simulation..." echo "Starting simulation..."