Skip to content

Releases: sigp/lighthouse

Cromulons

19 Sep 06:58
Compare
Choose a tag to compare
Cromulons Pre-release
Pre-release

Solves an issue which caused some nodes to stall during sync.

Changes

  • a17f748 Fix bad assumption when checking finalized descendant (#1629)
    • Fixes a "batch failed" error during syncing.
  • 49ab414 Shift gossipsub validation (#1612)
  • 2074bec Gossipsub message id to shortened bytes (#1607)
  • e5fc6ba Remove redundant decompression in process_deposit (#1610)
  • c9596fc Temporary Sync Work-Around (#1615)
  • c6abc56 Prevent large step-size parameters (#1583)
  • 7f1b936 ignore too early / too late attestations instead of penalizing them (#1608)
  • 810de2f Static testnet configs (#1603)
    • Solves issues downloading github files experienced by users behind the GFW. Thanks @danielschonfeld.
  • 0525876 Dial cached enr's before making subnet discovery query (#1376)
  • d79366c Prevent printing binary in RPC errors (#1604)
  • b19cf02 Penalise bad peer behaviour (#1602)
  • dfe5077 Remove references to rust-docs (#1601)

Binaries

Binaries are supplied for two platforms:

  • x86_64-unknown-linux-gnu: AMD/Intel 64-bit processors (most desktops, laptops, servers)
  • aarch64-unknown-linux-gnu: 64bit ARM processors (Raspberry Pi 4)

Additionally there is also a -portable suffix which indicates if the portable feature is used:

  • Without portable: uses modern CPU instructions to provide the fastest signature verification times (may cause Illegal instruction error on older CPUs)
  • With portable: approx. 20% slower, but should work on all modern 64-bit processors.

Jan-Michael Vincent

09 Sep 11:27
Compare
Choose a tag to compare
Jan-Michael Vincent Pre-release
Pre-release

This release contains new user facing functionality (key recovery) and fixes an issue which cause validators to produce attestations which would not be included on chain. We have observed significant improvement in rewards using this release.

Changes

  • Mnemonic key recovery (#1579)
    • Allows users to recover validator keys from mnemonics, thanks to @realbigsean
  • Update state before producing attestation (#1596)
    • Critical bug fix by @pawanjay176 which improves validator attestation inclusion.
  • Don't quote slot and epoch, for now (#1597)
  • Use simple logger builder pattern (#1594)
  • conforming to the p2p specs, requiring error_messages to be bound (#1593)
  • Update discv5 to v10 (#1592)
  • Add serde_utils module with quoted u64 support (#1588)
  • Revert "add a github action for build multi-arch docker images (#1574)" (#1591)
  • Avoid Printing Binary String to Logs (#1576)
  • add a github action for build multi-arch docker images (#1574)
  • Allow to use the same password when importing multiple keystores (#1479) (#1510)
    • Improves UX for importing from EF launchpad, thanks to @adetante
  • Minor documentation fixes (#1297)
  • Extended Gossipsub metrics (#1577)
  • Revert 1502 - Switching docker user to lighthouse (#1578)
  • Creates a new lighthouse user and makes it the default user to be use… (#1502)
  • Increase logging channel capacity (#1570)
  • Eth1 network exit on wrong network id (#1563)
  • Use Gossipsub 1.1 (#1516)
  • fix change flag name end_after_checks to continue_after_checks (#1573)

Binaries

Binaries are supplied for two platforms:

  • x86_64-unknown-linux-gnu: AMD/Intel 64-bit processors (most desktops, laptops, servers)
  • aarch64-unknown-linux-gnu: 64bit ARM processors (Raspberry Pi 4)

Additionally there is also a -portable suffix which indicates if the portable feature is used:

  • Without portable: uses modern CPU instructions to provide the fastest signature verification times (may cause Illegal instruction error on older CPUs)
  • With portable: approx. 20% slower, but should work on all modern 64-bit processors.

The President of the Miniverse

28 Aug 00:11
Compare
Choose a tag to compare
Pre-release

This release contains a fix to a known issue with the database which caused excessive database usage (>20gb when it should be ~8gb) and missing beacon state errors whilst syncing.

This release is compatible with existing databases, but you must re-sync if you wish to benefit from these fixes.

To reiterate, to repair a broken Lighthouse database please re-sync (lighthouse bn --purge-db) using this release.

Changes

  • Alternative (to BeaconChainHarness) BeaconChain testing API (#1380)
  • Check Cargo.lock freshness on CI (#1565)
    • Prevents releases from indicating the the git tree is dirty in the release tag.
  • Fix bug in database pruning (#1564)
    • Resolves issue regarding excessive database usage and issues during sync. Requires a full resync.
  • Fix order of testnet config load (#1558)
    • Fixes issues when using non-mainnet specifications (only relevant to developers).

Binaries

Binaries are supplied for two platforms:

  • x86_64-unknown-linux-gnu: AMD/Intel 64-bit processors (most desktops, laptops, servers)
  • aarch64-unknown-linux-gnu: 64bit ARM processors (Raspberry Pi 4)

Additionally there is also a -portable suffix which indicates if the portable feature is used:

  • Without portable: uses modern CPU instructions to provide the fastest signature verification times (may cause Illegal instruction error on older CPUs)
  • With portable: approx. 20% slower, but should work on all modern 64-bit processors.

Shmlangela Shmlobinson-Shmlower

24 Aug 11:04
Compare
Choose a tag to compare
Pre-release

This release contains a fix to a known deadlock condition (#1562) and should provide significant stability improvements for nodes which run high validator counts (>= 64).

Changes

  • Remove rayon from rest_api (#1562)
    • Prevents deadlock.
  • Shift HTTP server heavy-lifting to blocking executor (#1518)
    • Avoids locking the core executory.
  • reuse beacon_node methods for initializing network configs in boot_node (#1520)
  • Docs: Fix reference to incorrect password file. (#1556)
  • ban IP addresses if too many banned peers for this IP address (#1543)

Known Issues

There is a known issue with database pruning, causing failures during syncing and high disk usage. This is a major priority and a fix will be released ASAP.

Binaries

Binaries are supplied for two platforms:

  • x86_64-unknown-linux-gnu: AMD/Intel 64-bit processors (most desktops, laptops, servers)
  • aarch64-unknown-linux-gnu: 64bit ARM processors (Raspberry Pi 4)

Additionally there is also a -portable suffix which indicates if the portable feature is used:

  • Without portable: uses modern CPU instructions to provide the fastest signature verification times (may cause Illegal instruction error on older CPUs)
  • With portable: approx. 20% slower, but should work on all modern 64-bit processors.

Water-T

19 Aug 23:38
Compare
Choose a tag to compare
Water-T Pre-release
Pre-release

This release provides a significant stability improvement (#1546) and protects nodes against a DoS vector.

Changes

  • Refactor attestation service (#1415)
  • Shutdown like a Sir (#1545)
  • Add remaining network ops to queuing system (#1546)
    • Prevents locking when processing large numbers of slashings, as experienced on Medalla.

Binaries

Binaries are supplied for two platforms:

  • x86_64-unknown-linux-gnu: AMD/Intel 64-bit processors (most desktops, laptops, servers)
  • aarch64-unknown-linux-gnu: 64bit ARM processors (Raspberry Pi 4)

Additionally there is also a -portable suffix which indicates if the portable feature is used:

  • Without portable: uses modern CPU instructions to provide the fastest signature verification times (may cause Illegal instruction error on older CPUs)
  • With portable: approx. 20% slower, but should work on all modern 64-bit processors.

Elon Tusk

18 Aug 13:23
Compare
Choose a tag to compare
Elon Tusk Pre-release
Pre-release

Overview

This release provides a number of syncing improvements and stability updates. The majority of the updates are focused towards syncing and participating in the Medalla testnet along with adding support to migrate Prysm keystores into Lighthouse.

Notes

When syncing Medalla, there are a few large forks in existence. You may find your node shifting its view of the head slot quite a bit and sync may appear stalled. The node will sync all the forks and eventually find the true head. This can take up to 30-40 mins after it may look like sync has stalled. Once the network finalizes again, this will not be an issue.

Changes

  • Patch sync bugs leading to potential sync stalls (#1528)
  • Reduce the parallelism of syncing head chains. Makes syncing to head more efficient (#1527)
  • Prevent re-searching for failed forked chains (#1534)
  • Improve head syncing by removing potentially out-dated head sync chains (#1538)
  • Allow importing of Prysm keystores into lighthouse (#1535)
  • Add Lodestar as a known client (#1536)
  • Improve logging (#1541)
  • Set the default max-skip-slots to 700 to match observed chain on Medalla (#1542)

Octopus Man

17 Aug 13:52
Compare
Choose a tag to compare
Octopus Man Pre-release
Pre-release

This release provides significant performance and stability improvements in the presently unstable Medalla network. (Note: v0.2.3 was yanked).

Upgrade Notes

IMPORTANT: add the --max-skip-slots 700 flag to your beacon node. E.g., lighthouse bn --http --max-skip-slots 700 otherwise you will be unable to sync

If your node is trying to sync (i.e., not reporting Synced) or you're getting "skipping more than an epoch" warnings, we recommend:

  1. Stopping your validator client (it can't do anything useful until the BN is synced, and it'll just slow things down).
  2. Remove the database (lighthouse bn --purge-db).
  3. Keep an eye on the syncing process, if it becomes stuck for more than 20 minutes, restart the process. There are many nodes on the network returning incorrect or outdated responses, meaning it can take some time for Lighthouse to find good peers.

Known Issues

The turmoil on the Medalla testnet, some bugs in other client implementations and inefficiencies in our own is making it very difficult to sync Medalla. You may need to restart sync if you get stalled and memory/CPU usage will be much higher than usual.

Future release will follow in the coming days with further improvements.

Changes

  • Ignore blocks that skip a large distance from their parent (#1530)
    • Helps prevent excess memory usage.
  • Revert back to discv5 alpha 8 to maintain ARM support (#1531)
  • Ensure RUSTFLAGS is passed through on cross compile (#1529)
  • Process gossip blocks on the GossipProcessor (#1523)
    • Provides additional stability.
  • Memory usage reduction (#1522)
    • Helps prevent excess memory usage.
  • Remove yamux support (#1526)
  • Correct logic for peer sync identification (#1525)
  • Persist metadata and enr across restarts (#1513)
  • Add multiaddr support in bootnodes (#1481)
  • Update gossipsub duplicate cache (#1524)
  • Update discv5 to alpha.9 (#1517)
  • Commit Cargo.lock changes, add build scripts (#1521)
  • Update to v0.2.3 (#1519)
  • Restrict fork choice getters to finalized blocks (#1475)
    • Fixes some MissingBeaconState errors during attestation processing.
      *Introduce a queue for attestations from the network (#1511)
    • Provides significant performance and stability improvements.
  • Log to file without json format (#1485)
    • Default log file format is no longer JSON.
    • JSON is still supported via --log-format JSON.
  • Wind down the SSE thread when the client disconnects (#1514)
  • Update key-management.md (#1515)
  • Fix a bug in fork pruning (#1507)
  • Update key-management.md (#1508)
  • Prints the version when starting lighthouse (#1506)
  • Cross-compile to vendored x86_84, aarch64 (Raspberry Pi 4) (#1497)
  • Local testnet fixes (#1499)
  • Mitigate too many outgoing connections (#1469)
  • Add graffiti cli flag to the validator client. (#1425)
    • Users can now supply --graffiti to the lighthouse vc
  • Block error display (#1503)

Binaries

Binaries are supplied for two platforms:

  • x86_64-unknown-linux-gnu: AMD/Intel 64-bit processors (most desktops, laptops, servers)
  • aarch64-unknown-linux-gnu: 64bit ARM processors (Raspberry Pi 4)

Additionally there is also a -portable suffix which indicates if the portable feature is used:

  • Without portable: uses modern CPU instructions to provide the fastest signature verification times (may cause Illegal instruction error on older CPUs)
  • With portable: approx. 20% slower, but should work on all modern 64-bit processors.

Slick Morty

10 Aug 08:31
Compare
Choose a tag to compare
Slick Morty Pre-release
Pre-release

Overview

This release contains stability improvements and bug fixes in the networking stack.

This corrects an issue where nodes lost track of the head of the chain and required rebooting to rejoin the medalla network.

Details

  • a1f9769 Update to the latest libp2p - bug fixes including extra peer disconnect notifications (#1482)
  • 08a31c5 Bug fix to correctly disconnect and monitor peers that connect beyond our max peer limit (#1484)
  • 04e4389 Updates gossipsub to prevent O(N) lookups for duplicates and prevents the possibility of opening excessive substreams. This reduces CPU overhead of nodes. (#1490)
  • cbfae87 Updates discv5 to handle UDP port binding inside lighthouse as well as upgrading logs inside lighthouse to notify users if the address/port could not be bound to. (#1496)

Binaries

Binaries are supplied for two platforms:

  • x86_64-unknown-linux-gnu: AMD/Intel 64-bit processors (most desktops, laptops, servers)
  • aarch64-unknown-linux-gnu: 64bit ARM processors (Raspberry Pi 4)

Additionally there are two variants:

  • fast: uses modern CPU instructions to provide the fastest signature verification times (may cause Illegal instruction error on older CPUs)
  • portable: approx. 20% slower, but should work on all modern 64-bit processors.

Ghost in a Jar

06 Aug 22:44
Compare
Choose a tag to compare
Ghost in a Jar Pre-release
Pre-release

This release contains various bug fixes and an optimization for attestation inclusion.

Details

Attestation inclusion improvement

Networking

Misc

Terryfolds

04 Aug 09:40
Compare
Choose a tag to compare
Terryfolds Pre-release
Pre-release

The first official release for the Medalla testnet. It can be used to participate in Medalla genesis.

Users should upgrade to this release as soon as possible.