Skip to content

Releases: Consensys/teku

v0.12.8

27 Sep 21:26
60bc031
Compare
Choose a tag to compare
v0.12.8 Pre-release
Pre-release

Additions and Improvements

  • Added spadina network genesis state so an ETH1 endpoint is no longer required when connecting to Spadina.

Bug Fixes

  • Fixed issue where topped-up up deposits did not lead to activated validators.

v0.12.7

25 Sep 23:27
ee905b5
Compare
Choose a tag to compare
v0.12.7 Pre-release
Pre-release

Additions and Improvements

  • Added spadina network definition. As the genesis state is not yet known, an ETH1 endpoint must be specified when connecting to the spadina testnet
  • New REST APIs
    • /eth/v1/validator/duties/attester/:epoch - gets attester duties for the given epoch
    • /eth/v1/validator/duties/proposer/:epoch - gets block proposer duties for the given epoch
    • Deprecated POST /validator/duties, as the new standard endpoints are now implemented
    • eth/v1/beacon/genesis - retrieves details of the chain's genesis
    • Deprecated the previous genesis endpoint /node/genesis_time
    • /eth/v1/beacon/states/:state_id/validators/:validator_id - gets validator from state by id
    • /eth/v1/beacon/states/{state_id}/fork - gets Fork object for requested state
    • Deprecated the previous fork endpoint /node/fork
    • /eth/v1/events - subscribes to beacon node events
  • Implemented validator keystore file locking to prohibit another process using the same keys and getting slashed
  • Updated slashing protection interchange format version to v.4
  • Upgraded Jblst version to 0.2.0 which adds ARMv8 arch support
  • Implemented sending goodbye message to peers on shutdown
  • Reduced reorg noise during sync
  • Updated metrics library from Besu to latest version
  • Better handle P2P target peer bounds

Bug Fixes

  • Fixed debug-tools db subcommands to support writing UInt64 as YAML
  • Prevented fork choice head from going backwards when updating the chain

v0.12.6

09 Sep 01:01
c41c632
Compare
Choose a tag to compare
v0.12.6 Pre-release
Pre-release

Additions and Improvements

  • Added support for the slashing protection interchange format via the teku slashing-protection import and teku slashing-protection export subcommands
  • New REST APIs
    • /eth/v1/node/peers - lists information about the currently connected peers
    • /eth/v1/node/peers/:peer_id - list information about a specific peer
    • /eth/v1/node/health - return the node health status via HTTP status codes. Useful for load balancers
    • /eth/v1/node/syncing - describe the node's current sync status
    • /v1/node/version has been moved to /eth/v1/node/version and /v1/node/identity to /eth/v1/node/identity matching changes in the standard API spec
  • Gossip messages produced by Teku no longer set the from, signature or seqNo fields
  • Enabled Gossipsub flood publishing to reduce propagation times for attestations and blocks produced locally
  • Generated P2P private keys and Discovery v5 sequence numbers are now persisted across restarts
  • Implemented unicode normalization process for validator keystore passwords
  • Progress messages are now logged when loading large number of validator keys at startup
  • The default network is now Medalla instead of Altona
  • Avoid recalculating validator duties for reorgs that are not long enough to change the scheduling
  • Validator duties are now calculated as soon as the genesis state is known instead of waiting for the actual genesis time.
  • Added additional validation for deposit events received from the ETH1 node to flag when the ETH1 node has malfunctioned and missed some deposit log events
  • Exit with a clear message when the ETH1 service is unable to start. Note that this only applies when the existing deposit data is invalid. Teku will continue retrying if the ETH1 node is not currently available.
  • Operations (e.g. attestations, slashings etc) included in blocks are now readded to the pending pool if a reorg causes them to no longer be in the canonical chain
  • Removed support for generating unencrypted keystores
  • Discv5 now caches the hash of the local node to reduce load caused by significant numbers of incoming discovery messages
  • Early access support for running the validator node independently of the beacon node (see #2683 for details). Please note this is not yet a recommended configuration and the CLI options and APIs used are subject to change.

Bug Fixes

  • Gossip messages with null from, signature or seqNo fields are now rebroadcast with the fields still null instead of replaced by default values
  • Added validation to ensure that the uncompressed length of Gossip messages is within the possible ranges for a valid message for each gossip message type
  • Fixed validation of compressed gossip message length which may incorrectly reject messages
  • Fixed unhandled exception reported when an attestation received over gossip had an invalid checkpoint, specifying a block root from after the specified epoch.
  • Improved validation of remote peer status
  • Fix "AbstractRouter internal error on message control" errors when messages are received from peers before the outbound connection has been fully established
  • Fixed errors logged when the ETH1 chain is shorter than the configured follow distance
  • Explicitly fsync the RocksDB write ahead log files to disk on shutdown
  • Fixed issue where environment variables named TEKU_VERSION or TEKU_HELP would be incorrectly interpreted as specifying the --version and --help arguments, preventing Teku from starting
  • Avoid performing duplicate tasks to regenerate states in a particular corner case when the task can be rebased to start from the output of an already scheduled task
  • Improve performance of cacheable task queue used for state regeneration
  • Suppressed ClosedChannelException errors in logs

v0.12.5

27 Aug 04:45
a3f6ed9
Compare
Choose a tag to compare
v0.12.5 Pre-release
Pre-release

Bug Fixes

  • Fix race condition when a block and its parents are received at around the same time which could cause the node to fall out of sync until it reverted to syncing mode to catch up
  • Fix issue where attestations from blocks could be processed prior to the block they target being available resulting in ProtoNode: Delta to be subtracted is greater than node weight errors
  • Return a non-zero exit code from validator register subcommand when the user does not confirm the transaction

v0.12.4

25 Aug 21:52
4bbd0ac
Compare
Choose a tag to compare
v0.12.4 Pre-release
Pre-release

Upcoming Breaking Changes

  • REST API endpoints will be updated to match emerging standards in a future release.
  • --validators-key-files and --validators-key-password-files have been replaced by --validator-keys. The old arguments still work but will be removed in a future release.

Additions and Improvements

  • Includes a significant number of bug fixes and performance improvements as a result of the recent issues on the Medalla testnet. See #2596 for a full list of related issues.
  • Support loading an entire directory of validator keys using --validator-keys=<keyDir>:<passDir>. Individual keystore and password files can also be specified using this new argument.
  • Major reduction in CPU and memory usage during periods of non-finalization by intelligently queuing and combining requests for beacon states and checkpoint states
  • Fixed slow startup times during long periods of non-finalization. Non-finalized states are now periodically persisted to disk to avoid needing to replay large numbers of blocks to regenerate state.
  • Reduced sync times during long periods of non-finalization by searching for a more recent common ancestor than the finalized checkpoint
  • Added explicit UInt64 overflow and underflow protection
  • Local signing is now multithreaded to better utilise CPU when running large numbers of validators
  • Improved sync performance by continuing to update the target peer's status during the sync process
  • Removed support for SecIO. Only the NOISE handshake is now supported.
  • Provide a more userfriendly error message and exit if the P2P network port is already in use
  • Added new metrics
    • validator_attestation_publication_delay reports a histogram showing real time between when validations were due and when they were published to the network

Bug Fixes

  • Fixed issue where attestations were created for the wrong head because fork choice had not yet been run. Results in a significant improvement in attestation inclusion rate.
  • Fixed issue where invalid blocks were produced because they included attestations from forks that had different attestation committees
  • Fixed issue where block production may be scheduled for the wrong slot due to calculating duties one epoch ahead
  • Fixed issue where sync could appear to stall because fork choice data wasn't being updated during sync
  • Fixed race condition when updating fork choice votes which could lead to ProtoNode: Delta to be subtracted is greater than node weight errors
  • Reduce RejectedExecutionException noise in logs when Teku is unable to keep up with incoming gossip messages. Other performance improvements should also improve the ability to keep up.
  • Fixed cases where states were regenerated without first checking if a cached version was available
  • Fixed excessive memory usage in discovery when parsing an invalid RLP message
  • Fixed issue where maximum cache sizes could be exceeded resulting in excessive memory usage
  • Be more lenient in detecting peers that excessively throttle requests for blocks to better handle long stretches of empty slots
  • Fixed error when validating gossiped attestations that point to old blocks
  • Fixed netty thread blocked error messages from metrics by avoiding contention on key locks while retrieving metrics
  • Fixed issue where sockets were left open when using an external signer

v0.12.3

11 Aug 23:14
b0525ca
Compare
Choose a tag to compare
v0.12.3 Pre-release
Pre-release

Prebuilt binaries are available from https://bintray.com/consensys/pegasys-repo/teku/0.12.3#files

Breaking Changes

  • Removed --validators-unencrypted-key-files option. This was only intended for early interop testing. Keys should be loaded from encrypted keystores.

Additions and Improvements

  • Add basic built-in slashing protection. Note that this only a last line of defence against bugs in the beacon node and will not prevent slashing if validator keys are run in multiple processes simultaneously.
  • Validator duty logging is now enabled by default. It can be disabled with --log-include-validator-duties-enabled=false
  • Add updated Medalla bootnodes
  • Updated to be compliant with beacon chain spec 0.12.2
  • Prioritise more recent attestations when creating blocks as they pay higher rewards
  • Refuse to start if the existing database is from a different network to the current configuration
  • Added rate limiting for remote peers based on both number of blocks requested and total number of requests made
  • Discovery now requires confirmation from multiple peers before updating the external IP reported by the node
  • Improved interoperability with other clients: seqno field is now optional for libp2p messages
  • REST API updates:
    • Added genesis validator root to the /node/fork REST API
    • Added /validator/aggregate_attestation
    • Added /validator/persistent_subnets_subscription
    • Added /validator/beacon_committee_subscription
    • Added /validator/aggregate_and_proofs
    • Added /node/pending_attestation_count
  • Report the current peer count in "time to genesis"
  • Added UInt64 overflow and underflow detection
  • Improved performance of list shuffling operations
  • Snappy compression is now enabled by default for custom networks. It can be disabled with --p2p-snappy-enabled=false

Bug Fixes

  • Fixed vector for DOS attack caused by not throttling libp2p response rate. (See libp2p/jvm-libp2p#127 and ethereum/public-attacknets#7 for futher details)
  • Fixed issue that delayed publication of created attestations by a slot
  • Fixed "Invalid attestation: Signature is invalid" errors caused by incorrect caching of committee selections (see #2501 for further details)
  • Fixed issues where validators failed to perform duties because the node incorrectly returned to syncing state
  • Fixed --logging option to accept lowercase debug option. Renamed the debug subcommand to avoid the naming conflict
  • Avoid lock contention when reading in-memory storage metrics
  • Reduced memory usage when loading large numbers of scrypt encoded keystores
  • Increased read timeout for ETH1 requests to avoid repeatedly timing out when the ETH1 node is slow
  • Reduced noise in logs from ClosedChannelException when a peer unexpected disconnects
  • Fixed IllegalArgumentException when RPC response code was greater than 127
  • Fixed IllegalArgumentException when unexpectedly short discovery messages were received
  • Fixed very frequenet InternalErrorException when a peer disconnected during initial libp2p handshake
  • Fixed crash during shutdown caused by metrics accessing RocksDB after it was closed
  • Restricted the maximum epoch value accepted by REST API to ensure it can be converted to a slot without overflowing uint64
  • Fixed help text for --p2p-discovery-bootnodes

v0.12.2

28 Jul 23:43
c5d30ea
Compare
Choose a tag to compare
v0.12.2 Pre-release
Pre-release

Additions and Improvements

  • Added medalla network definition. As the genesis state is not yet known, an ETH1 endpoint must be specified when connecting to the medalla testnet
  • Attestations are now created and published immediately after the block for the slot is imported, instead of waiting until 1/3rd of the way through the slot
  • The Teku docker image has been upgraded to run Java 14
  • /beacon/state REST API now supports a stateRoot parameter to request states by state root. This includes retrieving states for empty slots
  • Reduced gas limit and used current gas price reported by the ETH1 node when sending deposit transactions with the validator subcommands
  • Validator keys are now loaded in parallel to improve start up time
  • Added a docker-compose configuration to quickly launch a 4-node local testnet
  • Exposed additional metrics to report on RocksDB memory usage:
    • storage_hot_estimated_table_readers_memory
    • storage_finalized_estimated_table_readers_memory
    • storage_hot_current_size_all_mem_tables
    • storage_finalized_current_size_all_mem_tables
  • Stricter req/resp message lengths are now enforced based on message content type

Bug Fixes

  • Significant reductions in process resident memory. As this involved a configuration change for RocksDB the most significant reduction is achieved with a new database
  • Fixed issue where Teku did not reconnect to peers after a network interruption
  • Fixed issue where Teku may stop attempting to create new outbound peer connections
  • Fixed incompatibility with deposits with public keys that could not be resolved to a G1 point
  • Avoid disconnecting peers that do not return all requested blocks for a block by range request
  • Reduced log level for a noisy message about duplicate peer connections

v0.12.1

15 Jul 03:20
f905ecd
Compare
Choose a tag to compare
v0.12.1 Pre-release
Pre-release

Breaking Changes

  • External signing API now uses the data field instead of signingRoot field when making signing requests. Update Eth2Signer to ensure it is compatible with this change.

Additions and Improvements

  • Further reduced memory usage during periods of non-finalization. Checkpoint states can now be dropped from memory and regenerated on demand.
  • Added additional metrics:
    • beacon_peer_count tracks the number of connected peers which have completed chain validation
    • network_peer_chain_validation_attempts tracks the number and status of peer chain validations
    • network_peer_connection_attempt_count tracks the number and status of outbound peer requests made
    • network_peer_reputation_cache_size reports the size of the peer reputation cache
    • beacon_block_import_total tracks the number of blocks imported
    • beacon_reorgs_total tracks the number of times a different fork is chosen as the new chain head
    • beacon_published_attestation_total tracks the total number of attestations sent to the gossip network
  • External signing API now uses the data field instead of signingRoot field when making signing requests. Eth2Signer has been updated with this change.
  • Enforced the 256 byte limit for Req/Resp error messages
  • Blocks by range requests which exceed the maximum block request count are now rejected rather than partially processed as required by the P2P specification
  • Improved tracking of peer reputation to avoid reattempting connections to peers we have previously rejected
  • ForkChoice data is now persistent to disk, improving startup times especially during long periods of non-finalization
  • Reduced the maximum number of blocks held in memory to reduce memory consumption during periods of non-finalization
  • Increased the defaults for the target peer count range
  • Actively manage peers to ensure we have at least some peers on each of the attestation subnets
  • Maintain a minimum number of randomly selected peers, created via outbound connections to provide Sybil resistance
  • Updated dependencies to latest versions

Bug Fixes

  • Fixed issue where the validator produced attestations in the incorrect slot or committee resulting in Produce invalid attestation messages
  • Fixed an issue where attestations were not published to gossip when the node was not subscribed to the attestation subnet
  • Fixed a number of unhandled exceptions in discv5
  • Fixed an issue where discv5 may return node responses with a total greater than 5
  • Fixed Trying to reuse disposable LengthPrefixedPayloadDecoder exception
  • Fixed an issue where peers were not disconnected when the initial status exchange failed
  • Fixed NullPointerException when validating attestations which became too old during validation
  • Updated the EXPOSE ports listed in the Dockerfile to match the new defaults
  • Fixed time until genesis log message to handle time zones correctly
  • Fixed NoSuchElementException when running a validator that was not in active status
  • Fixed IndexOutOfBoundsException when validating an IndexedAttestation which included invalid validator indices

v0.12.0

01 Jul 03:01
41f21d8
Compare
Choose a tag to compare
v0.12.0 Pre-release
Pre-release

Breaking Changes

  • Upgraded to v0.12.1 of the beacon chain spec. This is compatible with the Altona and Onyx testnets. For the Witti testnet use the 0.11.5 release.
  • --metrics-host-whitelist CLI option has been renamed --metrics-host-allowlist
  • --rest-api-host-whitelist CLI option has been renamed --rest-api-host-allowlist
  • The Rest interface is now correctly set from --rest-api-interface, so will need to be correctly configured to ensure
    that hosts specified in the --rest-api-host-allowlist are able to access that interface. Note that the default is to listen on localhost only.
  • --rest-api-enabled is now correctly used to determine whether to start the rest api. Ensure it is set if using the rest api. Note that the default is disabled.

Additions and Improvements

  • Support beacon chain spec v0.12.1.
  • The --network option now includes support for altona and onyx. The default network is now altona
  • Disk space requirements have been very significantly reduced, particularly when using archive storage mode
    • Finalized states are now stored in a separate database to non-finalized data.
      CLI options to store these under different directories are not yet available but will be considered in the future
    • Snapshots of finalized states are stored periodically. The data-storage-archive-frequency option controls how frequent these snapshots are.
      More frequent snapshots result in greater disk usage but improve the performance of API requests that access finalized state.
    • Due to the way regenerated states are cached, iterating through slots in increasing order is significantly faster than iterating in decreasing order
  • Teku now exposes RocksDB metrics to prometheus
  • The genesis state root, block root and time are now printed at startup
  • The time to genesis being reached is now output every 10 minutes, so that it's visibly apparent that teku is still running
  • Requests made to ETH1 nodes now include the Teku version as the user agent
  • Unstable options can now be listed with teku -X. These options may be changed at any time without warning and are generally not required, but can be useful in some situations.
  • Added a bash/zsh autocomplete script for Teku options and subcommands
  • Reduced memory usage of state caches
  • The list of validators being run is now printed to the console instead of just the log file

Bug Fixes

  • Fixed a very common error message while handling received attestations from peers
  • Reduced log level of Connection reset log messages from NoiseXXSecureChannel.
  • Fixed an issue where the last ETH1 block with deposits was processed twice when Teku was restarted pre-genesis. This resulted in an incorrect genesis state being generated.
  • Update the private key message at startup to more clearly indicate it is referring to the ENR.
  • The --rest-api-interface configuration attribute is now set on the HTTP server, it no longer listens on all interfaces.
  • The --rest-api-enabled flag will determine whether the http server actually starts and binds to a port now.
  • Fixed minor memory leak in storage
  • Fixed potential crashes in RocksDB while shutting down Teku.
  • Fixed an incompatibility with other clients due to Teku incorrectly expecting a length prefix for metadata requests
  • When no advertised IP is specified and the p2p-interface is set to 0.0.0.0 or some other "any local" address,
    Teku will now resolve the IP for localhost instead of using the "any local" address in it's initial ENR.

Known Issues

  • Validator may produce attestations in the incorrect slot or committee resulting in Produced invalid attestation messages (#2179)

v0.11.4

17 Jun 02:58
f808391
Compare
Choose a tag to compare
v0.11.4 Pre-release
Pre-release

Breaking Changes

  • teku validator generate no longer sends ETH1 deposit transactions. It only generates BLS keys for validators.
    The new teku validator generate-and-register subcommand can be used to generate and register validators in one step

Additions and Improvements

  • Renamed --metrics-host-whitelist to --metrics-host-allowlist and --rest-api-host-whitelist to --rest-api-host-allowlist
  • Added /v1/node/version and /v1/node/identity REST endpoints. Anyone using /node/version should switch to use
    the new endpoint, as /node/version will be removed in a future release.
  • Added --validators-graffiti="GRAFFITI" command line option to allow graffiti to be used in block production.
  • The Teku version is now printed at startup
  • Eth1 deposits now load on startup from the local database, then sync to the eth1 provider once loading is complete.
    A hidden flag has been added to disable this functionality if it causes any issues - --Xeth1-deposits-from-storage-enabled=false.
    Local storage requirements will increase slightly due to the need to store each deposit block
    event from the eth1 provider so that it can be replayed during restarts.
  • Added a teku debug db get-deposits subcommand to load report the ETH1 deposits from the database. This is not intended for normal use but can be useful when debugging issues.
  • The directory structure created by validator generate has changed. All files are now generated in a single directory.
    Filename of withdrawal key is now named using the validator public key eg 814a1a6_validator.json 814a1a6_withdrawal.json
  • Validator voluntary exit gossip topics are now supported
  • Proposer slashing gossip topics are now supported
  • Attester slashing gossip topics are now supported
  • Added support for Gossipsub 1.1
  • Building from downloaded source packages rather than git checkout now works
  • Memory requirements during non-finalized periods has been reduced, but further work is required in this area
  • REST API documentation is automatically published to https://pegasyseng.github.io/teku/ as soon as changes are merged
  • A memory dump is now captured if Teku encounters and out of memory error. By default these are
    written to the current work directory but an alternate location can be specified by setting the
    environment variable TEKU_OPTS=-XX:HeapDumpPath=/path
    This can be disabled by setting TEKU_OPTS=-XX:-HeapDumpOnOutOfMemoryError
  • Treat attestations from verified blocks or produced in the validator as "seen" for gossip handling
  • Added metrics to report the active and live validators for the current and previous epochs
    (beacon_previous_live_validators, beacon_previous_active_validators, beacon_current_live_validators, beacon_current_active_validators)
  • Added metrics to report on the in-memory store. Includes state cache hit/miss rates and the current number of states, blocks and checkpoint states held in the store.
  • Optimised decompression of points in BLS
  • Keystores generated with Teku are now compatible with Lighthouse
  • Added additional logging during start up to provide progress information while hot states are being regenerated
  • Integrated the new fork choice reference tests

Bug Fixes

  • Fixed StackOverflowException from fork choice get_ancestor method during long periods of non-finalization
  • Fixed issue where ETH1 events could be missed immediately after startup resulting in an incorrect genesis state being generated
  • Fixed issue where the beacon node was considered in-sync prior to finding any peers
  • Recalculate validator duties when a block is imported which may affect duty scheudling.
    This occurs when blocks are delayed for more than epoch, for example due to a network outage
  • Block production no longer fails if the Eth1Data vote in the new block is the last required vote
    for that Eth1Data and the new Eth1Data allows inclusion of new deposits
  • io.netty.handler.timeout.ReadTimeoutException and io.netty.channel.ExtendedClosedChannelException are no longer reported at ERROR level
  • Fix attestation is invalid error messages caused by a race condition verifying signatures
  • Support zero-roundtrip multistream negotiations in libp2p
  • Fix missed assertion in fork choice which could lead to an IndexOutOfBoundException (not consensus affecting)
  • Clarified the "Minimum genesis time reached" message to be clearer that this only indicates that an
    ETH1 block satisfying the time criteria for genesis has been found.
    Additional validators may still be required before the genesis state is known.
  • Fixed a number of error messages that were logged during Teku shutdown
  • Respect the optional epoch paramter to the /beacon/validators REST API endpoint
  • Fix "Command too long" error when running on Windows
  • Fixed issue where exceptions may be reported by the uncaught exception handler instead of reported back to the original caller.
    This resulted in some RPC streams not being closed correctly.
  • Fixed execessive use of CPU regenerating states to map slots to block roots while servicing beacon block by root RPC requests.