Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: 1.24.0 release #7287

Closed
wants to merge 37 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
99c0dcb
feat: add keymanager endpoint to retrieve proposer config (#7210)
nflaig Oct 30, 2024
794e5ef
feat: add mekong network option (#7212)
nflaig Nov 1, 2024
06b4c2d
chore: fix import order with biome syntax (#7211)
nazarhussain Nov 1, 2024
07d1145
fix: consistently validate pubkey and throw 404 if not found (#7214)
nflaig Nov 3, 2024
abe6751
fix: only return local keys from /eth/v1/keystores (#7215)
nflaig Nov 3, 2024
2e5265b
feat: add and use getBlobsV1 to expedite gossip import (#7134)
g11tech Nov 3, 2024
e2c45b9
chore: revert async aggregate with randomness (#7218)
matthewkeil Nov 7, 2024
2e8b8bb
fix: update config for relaunched mekong network (#7220)
nflaig Nov 8, 2024
10d15dc
fix: light client generating `LightClientUpdate` with wrong length of…
ensi321 Nov 8, 2024
0d404f8
fix: archive finalized state when shutting down beacon node (#7221)
nflaig Nov 8, 2024
6039f58
Merge branch 'stable' into unstable
nflaig Nov 11, 2024
1fae968
Fix typo
ensi321 Nov 17, 2024
25c2ee5
chore: several typos from bots (#7228)
nflaig Nov 17, 2024
b78cb92
feat: remove unfinalized pubkey cache (#7230)
ensi321 Nov 25, 2024
18f4218
chore: skip web3_provider unit tests (#7252)
nflaig Nov 27, 2024
e86e816
fix: prune checkpoint states at syncing time (#7241)
twoeths Nov 27, 2024
443e3a8
fix: sync cached isCompoundingValidatorArr at epoch transition (#7247)
twoeths Nov 27, 2024
0c1ad93
fix: handle outOfRangeData when range sync Deneb (#7249)
twoeths Nov 27, 2024
48dea55
fix: sync cached balance when adding new validator to registry (#7255)
twoeths Nov 28, 2024
aaac34a
fix: do not throw error when trying to prune missing directory (#7257)
nflaig Nov 29, 2024
c9af6c3
docs: update documentation Oct 2024 (#7178)
philknows Nov 29, 2024
dc4f36d
Merge branch 'stable' into unstable
nflaig Nov 29, 2024
8922d55
chore(deps): bump cross-spawn from 7.0.3 to 7.0.6 in /docs (#7268)
dependabot[bot] Nov 29, 2024
64eb015
feat: add error log to notifier if execution client auth failed (#7239)
nflaig Dec 2, 2024
84e0699
docs: display rcConfig flag on CLI reference page (#7270)
nflaig Dec 3, 2024
376fe2a
chore: remove prettier as default formatter for all file types (#7275)
nflaig Dec 3, 2024
37c4287
chore: unhide flags relevant for devnets / testing (#7271)
nflaig Dec 3, 2024
dbe2188
feat: debug too many shuffling promises (#7251)
matthewkeil Dec 4, 2024
69ae688
chore: unpin nodejs version from 22.4 (#6982)
nazarhussain Dec 4, 2024
b5fb76c
chore: update bootnodes file url for holesky and sepolia (#7276)
nflaig Dec 5, 2024
d55bb2d
feat: add `debug_getHistoricalSummaries` endpoint (#7245)
acolytec3 Dec 5, 2024
86ed6f4
chore: log sync committee signature errors as `error` (#7283)
nflaig Dec 6, 2024
cd1211f
fix: update engine_getClientVersionV1 commit encoding (#7282)
nflaig Dec 6, 2024
e353f67
fix: check pubkey or validator index known to a state (#7284)
twoeths Dec 6, 2024
f87eb0b
feat: lodestar script setup (#7254)
varunguleriaCodes Dec 6, 2024
75ff604
chore: bump package versions to 1.24.0
philknows Dec 6, 2024
1318712
chore: pin nodejs version to 22.4 (#7291)
wemeetagain Dec 12, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ docs/pages/libraries/lightclient-prover/lightclient.md
docs/pages/libraries/lightclient-prover/prover.md
docs/pages/api/api-reference.md
docs/pages/contribution/getting-started.md
docs/static/install
## Docusaurus
docs/.docusaurus/
docs/build/
Expand Down
9 changes: 7 additions & 2 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
{
"window.title": "${activeEditorShort}${separator}${rootName}${separator}${profileName}${separator}[${activeRepositoryBranchName}]",
"editor.defaultFormatter": "esbenp.prettier-vscode",
// For `sysoev.vscode-open-in-github` extension
"openInGitHub.defaultBranch": "unstable",
"editor.formatOnSave": true,
Expand All @@ -18,5 +17,11 @@
},
"[jsonc]": {
"editor.defaultFormatter": "biomejs.biome"
}
},
"[yaml]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"[markdown]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
}
28 changes: 28 additions & 0 deletions .wordlist.txt
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
API
APIs
Andreas
Antonopoulos
Expand All @@ -13,6 +14,7 @@ Casper
Chai
ChainSafe
Codespaces
CoinCashew
Corepack
Customizations
DPoS
Expand All @@ -29,6 +31,7 @@ ENRs
ETH
Edgington
Erigon
Esat
EthStaker
EtherScan
Ethereum
Expand All @@ -37,15 +40,19 @@ FINDNODE
FX
Flamegraph
Flamegraphs
GPG
Geth
Github
Goerli
Golang
Gossipsub
Grafana
Grandine
HTTPS
HackMD
Hashicorp
Homebrew
Hyperledger
IPFS
IPv
Infura
Expand All @@ -60,15 +67,18 @@ LGPLv
LMD
LPoS
LTS
LVM
Lerna
MEV
MacOS
Metamask
MevBoost
ModuleNotFoundError
Monorepo
NPM
NVM
Nethermind
Nim
NodeJS
NodeSource
OSI
Expand All @@ -81,9 +91,11 @@ Quickstart
RPC
Reth
Ryzen
SFTP
SHA
SSD
SSZ
Somer
Stakehouse
TOC
TTD
Expand All @@ -98,18 +110,21 @@ Vitalik
Vitest
Wagyu
api
args
async
backfill
beaconcha
blockRoot
blockchain
blockspace
blst
bootnode
bootnodes
bundlers
chainConfig
chainsafe
chiado
chmod
cli
cmd
codebase
Expand All @@ -125,6 +140,8 @@ dApp
dApps
ddos
decrypt
decrypted
derypted
deserialization
dev
devcontainer
Expand All @@ -139,30 +156,38 @@ env
envs
ephemery
ethers
feeRecipient
flamegraph
flamegraphs
floodsub
fsSL
getNetworkIdentity
gnosis
gpg
heapdump
heaptrack
holesky
interop
js
keymanager
keypair
keyrings
keystore
keystores
libp
lightclient
linter
liveness
lldb
llnode
lockfile
mainnet
malloc
mbps
mdns
merkle
merkleization
misconfiguration
mmeshsub
monorepo
multiaddr
Expand Down Expand Up @@ -199,6 +224,7 @@ ssz
stakers
subnet
subnets
sudo
tcp
testnet
testnets
Expand All @@ -215,6 +241,8 @@ vite
vitest
webpack
wip
xRelayPubKey
xcode
yaml
yamux
yml
5 changes: 1 addition & 4 deletions biome.jsonc
Original file line number Diff line number Diff line change
Expand Up @@ -18,10 +18,7 @@
"ignore": ["**/lib", "**/.nyc_output", "./packages/*/spec-tests", "**/node_modules", "./packages/*/node_modules/**"]
},
"organizeImports": {
// TODO: We will enable this settings as soon mono-repo support is provided in biome.
// Currently it didn't recognize local packages in repo and sort those higher than npm packages
// https://github.com/biomejs/biome/issues/2228
"enabled": false
"enabled": true
},
"linter": {
"enabled": true,
Expand Down
2 changes: 1 addition & 1 deletion docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,4 +22,4 @@ This command starts a local development server and opens up a browser window. Mo
$ yarn build
```

This command generates static content into the `build` directory and can be served using any static contents hosting service.
This command generates static content into the `build` directory and can be served using any static content hosting service.
32 changes: 13 additions & 19 deletions docs/docusaurus.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -97,29 +97,23 @@ const config: Config = {
style: "dark",
links: [
{
title: "Docs",
items: [
{
label: "Introduction",
to: "/introduction",
},
],
label: 'Lodestar Website',
href: 'https://lodestar.chainsafe.io',
},
{
title: "Community",
items: [
{
label: "Discord",
href: "https://discord.com/invite/yjyvFRP",
},
{
label: "Twitter",
href: "https://twitter.com/lodestar_eth",
},
],
label: 'Discord',
href: 'https://discord.com/invite/yjyvFRP',
},
{
label: 'Twitter/X',
href: 'https://x.com/lodestar_eth',
},
{
label: 'Github',
href: 'https://github.com/ChainSafe/lodestar',
},
],
copyright: `Copyright © ${new Date().getFullYear()} ChainSafe, Inc.`,
copyright: `Copyright © ${new Date().getFullYear()} ChainSafe. Built with Docusaurus.` ,
},
colorMode: {
respectPrefersColorScheme: false,
Expand Down
1 change: 0 additions & 1 deletion docs/pages/google0c42298b7ec08b7e.html

This file was deleted.

24 changes: 14 additions & 10 deletions docs/pages/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,14 @@ title: Home

![lodestar logo](../../assets/lodestar_icon_text_black_stroke.png)

## Welcome to the Lodestar documentation
## Welcome to the Lodestar Documentation

> **Lodestar is an open-source Ethereum Consensus client and Typescript ecosystem, maintained by ChainSafe Systems**
> **Lodestar is an open-source Ethereum Consensus client and TypeScript ecosystem, maintained by ChainSafe Systems**

### Getting started
### Getting Started

- Follow the instructions for [build from source](./run/getting-started/installation#build-from-source), [binaries](./run/getting-started/installation#binaries), or [Docker](./run/getting-started/installation#docker-installation) to install Lodestar. Or use our [Lodestar Quickstart scripts](https://github.com/ChainSafe/lodestar-quickstart).
- Use [Lodestar libraries](./supporting-libraries/index.md) in your next Ethereum Typescript project.
- Use [Lodestar libraries](./supporting-libraries/index.md) in your next Ethereum TypeScript project.
- Run a beacon node on [mainnet or a public testnet](./run/beacon-management/starting-a-node.md).
- Utilize the whole stack by [starting a local testnet](./contribution/advanced-topics/setting-up-a-testnet.md).
- View the Lodestar Beacon [CLI commands and options](./run/beacon-management/beacon-cli.md)
Expand All @@ -26,14 +26,18 @@ Hardware specifications minimum / recommended, to run the Lodestar client.
| | Minimum | Recommended |
| --------- | -------------------------------------- | -------------------------------------- |
| Processor | Intel Core i3–9100 or AMD Ryzen 5 3450 | Intel Core i7–9700 or AMD Ryzen 7 4700 |
| Memory | 16GB RAM | 32GB RAM |
| Storage | 100GB available space SSD | 1TB available space SSD |
| Internet | Broadband connection | Broadband connection |
| Memory | 8 GB RAM | 16 GB RAM |
| Storage | 130 GB available space SSD | 200 GB available space SSD |
| Internet | Reliable broadband with 10mbps upload | Reliable broadband with >10mbps upload |

## About these docs
### Execution Client

This documentation is open source, contribute at [Github Lodestar repository /docs](https://github.com/ChainSafe/lodestar/tree/unstable/docs).
If you run the [execution client](https://ethereum.org/en/developers/docs/nodes-and-clients/#execution-clients) on the same host, you will need to check their requirements and add them to the above requirements. Broadly, to run both an execution and a consensus client on the same machine, we recommend a 4 TB SSD and 32 GB RAM.

## Need assistance?
## About These Docs

This documentation is open source, contribute on our [Github Lodestar repository /docs](https://github.com/ChainSafe/lodestar/tree/unstable/docs).

## Need Assistance?

If you have questions about this documentation, feel free to talk to us on our [ChainSafe Discord](https://discord.gg/yjyvFRP) or [open an issue](https://github.com/ChainSafe/lodestar/issues/new/choose) and a member of the team or our community will be happy to assist you.
24 changes: 12 additions & 12 deletions docs/pages/introduction.md
Original file line number Diff line number Diff line change
@@ -1,29 +1,29 @@
# Introduction

Ethereum is one of the most profoundly important inventions in recent history. It is a decentralized, open-source blockchain featuring smart contract functionality. It is the second-largest cryptocurrency by market capitalization, after Bitcoin, and is the most actively used blockchain. Ethereum was proposed in 2013 by programmer Vitalik Buterin. Development was crowdfunded in 2014, and the network went live on 30 July 2015, with 72 million coins premined. ChainSafe was founded not too long afterwards and has been actively working in the Ethereum space ever since. We are proud to develop Lodestar and to present this documentation as a resource for the Ethereum community.
Ethereum is one of the most profoundly important inventions in recent history. It is a decentralized, open-source blockchain featuring smart contract functionality. It is the second-largest cryptocurrency by market capitalization, after Bitcoin, and is the second largest blockchain by market capitalization. Ethereum was proposed in 2013 by programmer Vitalik Buterin. Development was crowdfunded in 2014, and the network went live on 30 July 2015, with 72 million coins premined. ChainSafe was founded not too long afterwards in 2017 and has been actively working in the Ethereum ecosystem ever since. We are proud to develop Lodestar, the only TypeScript based consensus client, and to present this documentation as a resource for the Ethereum community.

## Proof of Stake

In Ethereum's Proof of Stake (PoS) model, validators replace miners from the Proof of Work (PoW) system. Validators are Ethereum stakeholders who lock up a portion of their Ether as a stake. The protocol randomly selects these validators to propose new blocks. The chance of being chosen is tied to the size of their stake: the more Ether staked, the higher the probability of being selected to propose the block. Proposers receive transaction fees and block rewards as incentives. Validators are also responsible for voting on the validity of blocks proposed by other validators. However, they face penalties, known as slashing, for actions like double-signing, votes on a block that is not in the majority or going offline, ensuring network integrity and reliability. The PoS mechanism significantly reduces energy consumption compared to PoW, because it does not require extensive computational power. Moreover, PoS tends to facilitate faster transaction validations and block creations, enhancing the overall performance and scalability of the network.
In Ethereum's Proof of Stake (PoS) model, validators replace miners from the Proof of Work (PoW) system. Validators are Ethereum stakeholders who lock up a portion of their Ether as a stake. The protocol randomly selects these validators to propose new blocks. The chance of being chosen is tied to the size of their stake: the more Ether staked, the higher the probability of being selected to propose the block. Proposers receive transaction fees and block rewards as incentives. Validators are also responsible for voting on the validity of blocks proposed by other validators. However, they also face penalties, known as slashing, for actions like signing two different block proposals in the same slot or voting on two different attestations for the same target epoch, which creates conflicting states. The PoS mechanism significantly reduces energy consumption compared to PoW, because it does not require extensive computational power. Moreover, PoS tends to facilitate faster transaction validations and block creations, enhancing the overall performance and scalability of the network.

## Consensus Clients

In an effort to promote client diversity there are several beacon-nodes being developed. Each is programmed in a different language and by a different team. The following is a list of the current beacon-node clients:
In an effort to promote client diversity there are several consensus beacon nodes being developed. Each is programmed in a different language and by a different team. The following is a list of the current open source consensus clients in alphabetical order:

- [Lodestar](https://lodestar.chainsafe.io/)
- [Prysm](https://prysmaticlabs.com/)
- [Lighthouse](https://lighthouse.sigmaprime.io/)
- [Teku](https://consensys.net/knowledge-base/ethereum-2/teku/)
- [Nimbus](https://nimbus.team/)
- [Grandine](https://grandine.io)
- [Grandine (Rust)](https://grandine.io)
- [Lighthouse (Rust)](https://lighthouse.sigmaprime.io/)
- [Lodestar (TypeScript)](https://lodestar.chainsafe.io/)
- [Nimbus (Nim)](https://nimbus.team/)
- [Prysm (Golang)](https://prysmaticlabs.com/)
- [Teku (Java)](https://consensys.net/knowledge-base/ethereum-2/teku/)

## Why Client Diversity?

The Ethereum network's robustness is significantly enhanced by its client diversity, whereby multiple, independently-developed clients conforming to a common specification facilitate seamless interaction and function equivalently across nodes. This client variety not only fosters a rich ecosystem but also provides a buffer against network-wide issues stemming from bugs or malicious attacks targeted at particular clients. For instance, during the Shanghai denial-of-service attack in 2016, the diversified client structure enabled the network to withstand the assault, underscoring the resilience afforded by multiple client configurations.
The Ethereum network's robustness is significantly enhanced by its client diversity, whereby multiple, independently-developed clients conforming to a common specification, facilitating seamless interaction and function equivalently across different nodes. This client variety not only fosters a rich ecosystem but also provides a buffer against network-wide issues stemming from bugs or malicious attacks targeted at particular clients. For instance, during the Shanghai denial-of-service attack in 2016, the diversified client structure enabled the network to withstand the assault, underscoring the resilience afforded by multiple client configurations.

On the consensus layer, client distribution is crucial for maintaining network integrity and finality, ensuring transactions are irreversible once validated. A balanced spread of nodes across various clients helps mitigate risks associated with potential bugs or attacks that could, in extreme cases, derail the consensus process or lead to incorrect chain splits, thereby jeopardizing the network's stability and trust. While the data suggests a dominance of Prysm client on the consensus layer, efforts are ongoing to promote a more even distribution among others like Lighthouse, Teku, Nimbus and Grandine. Encouraging the adoption of minority clients, bolstering their documentation, and leveraging real-time client diversity dashboards are among the strategies being employed to enhance client diversity, which in turn fortifies the Ethereum consensus layer against adversities and fosters a healthier decentralized network ecosystem.
On the consensus layer, client distribution is crucial for maintaining network integrity and finality, ensuring transactions are irreversible once validated. A balanced spread of nodes across various clients help to mitigate risks associated with potential bugs or attacks that could, in extreme cases, derail the consensus process (liveness failure) or lead to incorrect chain splits (forking), thereby jeopardizing the network's stability and trust. While the data suggests a [dominance of the Prysm and Lighthouse clients](https://clientdiversity.org) on the consensus layer, efforts are ongoing to promote a more even distribution among others clients. Encouraging the adoption of minority clients, bolstering their documentation, and leveraging real-time client diversity dashboards are among the strategies being employed to enhance client diversity, which in turn fortifies the Ethereum consensus layer against adversities and fosters a healthier decentralized network.

The non-finality event in May 2023 on the Ethereum network posed a significant challenge. The issue arose from attestations for a fork, which necessitated state replays to validate the attestations, causing a notable strain on system resources. As a result, nodes fell out of sync, which deterred the accurate tracking of the actual head of the chain. This situation was exacerbated by a decline in attestations during specific epochs, further hampering the consensus mechanism. The Lodestar team noticed late attestations several weeks prior to the event and implemented a feature that attempted to address such challenges by not processing untimely attestations, and thus not requiring expensive state replays​. While it was done for slightly different reasons, the result was the same. Lodestar was able to follow the chain correctly and helped to stabilize the network. This example underscored the importance of client diversity and network resilience against potential forks and replay attacks. These are considered realistic threats, especially in the context of system complexity like in Ethereum's consensus mechanism.
The [non-finality event of May 2023](https://medium.com/offchainlabs/post-mortem-report-ethereum-mainnet-finality-05-11-2023-95e271dfd8b2) on the Ethereum network posed a significant challenge. The issue arose from attestations for a fork, which necessitated state replays to validate the attestations, causing a notable strain on system resources. As a result, nodes fell out of sync, which deterred the accurate tracking of the actual head of the chain. This situation was exacerbated by a decline in attestations during specific epochs, further hampering the consensus mechanism from reaching finality. The Lodestar team noticed late attestations several weeks prior to the event and implemented a feature that attempted to address such challenges by not processing untimely attestations, and thus not requiring expensive state replays​. While it was done for slightly different reasons, the result was the same. Lodestar was able to follow the chain correctly and helped to stabilize the network. This example underscored the importance of client diversity and network resilience against potential forks and replay attacks. These are considered realistic threats, especially in the context of system complexity like in Ethereum's consensus mechanism.

## Ethereum Reading List

Expand Down
Loading
Loading