-
-)
-
-export default PreMergeBanner
diff --git a/src/content/community/support/index.md b/src/content/community/support/index.md
index 0b90a73463c..4711daa22e3 100644
--- a/src/content/community/support/index.md
+++ b/src/content/community/support/index.md
@@ -107,4 +107,8 @@ Transactions on Ethereum can sometimes get stuck if you have submitted a lower t
#### How do I mine Ethereum? {#mining-ethereum}
-We do not recommend buying mining equipment if you are not already mining Ethereum. In ~Q3/Q4 2022, [The Merge](/upgrades/merge/) will happen, switching Ethereum from proof-of-work to proof-of-stake. This change means mining Ethereum will no longer be possible.
+Ethereum mining is no longer possible. Mining was switched off when Ethereum moved from proof-of-work to proof-of-stake. Now, instead of miners, Ethereum has validators. Validators stake ETH and receive staking rewards for securing the network.
+
+#### How do I become a staker/validator? {#become-validator}
+
+To become a validator, you must stake 32 ETH in the Ethereum deposit contract and set up a validator node. More information is available on our [staking pages](/staking) and at [the staking launchpad](https://launchpad.ethereum.org/).
diff --git a/src/content/dao/index.md b/src/content/dao/index.md
index d7883bada53..08eb312e2ae 100644
--- a/src/content/dao/index.md
+++ b/src/content/dao/index.md
@@ -70,14 +70,15 @@ There are many considerations when governing a DAO, such as how voting and propo
### Delegation {#governance-delegation}
-Delegation is like the DAO version of representative democracy. Token holders delegate votes to users who nominate themselves and commit to stewarding the protocol and staying informed.
+Delegation is like the DAO version of representative democracy. Token holders delegate votes to users who nominate themselves and commit to stewarding the protocol and staying informed.
#### A famous example {#governance-example}
[ENS](https://claim.ens.domains/delegate-ranking) – ENS holders can delegate their votes to engaged community members to represent them.
### Automatic transaction governance {#governance-example}
-In many DAOs, transactions will be automatically executed if a quorum of members votes affirmative.
+
+In many DAOs, transactions will be automatically executed if a quorum of members votes affirmative.
#### A famous example {#governance-example}
diff --git a/src/content/deprecated-software/index.md b/src/content/deprecated-software/index.md
index fc098d2c6f6..9a5a5072b65 100644
--- a/src/content/deprecated-software/index.md
+++ b/src/content/deprecated-software/index.md
@@ -12,6 +12,10 @@ This is a list of key Ethereum-related projects and resources which have been de
This list is curated by our community. If there's something missing or incorrect, please edit this page!
+## Proof-of-work {#pow}
+
+[Proof of work](/developers/docs/consensus-mechanisms/pow) is a consensus engine that was implemented in Ethereum until September 2022. It was deprecated when Ethereum swapped to a [proof-of-stake](/developers/docs/consensus-mechanisms/pos) based consensus mechanism. This was achieved by deprecating the parts of the client software related to proof-of-work mining, including [Ethhash](/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethhash) (the mining algorithm) and all the consensus logic and block gossiping functionality that was originally built in to execution clients. The clients themselves were not deprecated but several of their core components were. The concept of proof-of-work was deprecated as the total effect of removing the related components of the client software.
+
## Software {#software}
This section is for software for the desktop, command line, or server which has been deprecated. The main types are wallets, integrated development environments, languages, and Ethereum clients. Definitely be careful to not install deprecated software unless you are certain it is from the original source, e.g. a repo hosted under https://github.com/ethereum.
diff --git a/src/content/developers/docs/accounts/index.md b/src/content/developers/docs/accounts/index.md
index 85651ac4a30..eb07032fdca 100644
--- a/src/content/developers/docs/accounts/index.md
+++ b/src/content/developers/docs/accounts/index.md
@@ -99,6 +99,12 @@ Example:
The contract address is usually given when a contract is deployed to the Ethereum Blockchain. The address comes from the creator's address and the number of transactions sent from that address (the “nonce”).
+## Validator keys {#validators-keys}
+
+There is also another type of key in Ethereum, introduced when Ethereum switched from proof-of-work to proof-of-stake based consensus. These are 'BLS' keys and they are used to identify validators. These keys can be efficiently aggregated to reduce the bandwidth required for the network to come to consensus. Without this key aggregation the minimum stake for a validator would be much higher.
+
+[More on validator keys](/developers/docs/consensus-mechanisms/pos/keys/).
+
## A note on wallets {#a-note-on-wallets}
An account is not a wallet. An account is the keypair for a user-owned Ethereum account. A wallet is an interface or application that lets you interact with your Ethereum account.
diff --git a/src/content/developers/docs/apis/javascript/index.md b/src/content/developers/docs/apis/javascript/index.md
index d1a7023f8bf..fb17cef21f6 100644
--- a/src/content/developers/docs/apis/javascript/index.md
+++ b/src/content/developers/docs/apis/javascript/index.md
@@ -11,6 +11,8 @@ For this purpose, every Ethereum client implements the [JSON-RPC](/developers/do
If you want to use JavaScript to connect with an Ethereum node, it's possible to use vanilla JavaScript but several convenience libraries exist within the ecosystem that make this much easier. With these libraries, developers can write intuitive, one-line methods to initialize JSON RPC requests (under the hood) that interact with Ethereum.
+Please note that since [The Merge](/upgrades/merge/), two connected pieces of Ethereum software - an execution client and a consensus client - are required to run a node. Please ensure your node includes both an execution and consensus client. If your node is not on your local machine (e.g. your node is running on an AWS instance) update the IP addresses in the tutorial accordingly. For more information please see our page on [running a node](/developers/docs/nodes-and-clients/run-a-node/).
+
## Prerequisites {#prerequisites}
As well as understanding JavaScript, it might be helpful to understand the [Ethereum stack](/developers/docs/ethereum-stack/) and [Ethereum clients](/developers/docs/nodes-and-clients/).
diff --git a/src/content/developers/docs/apis/json-rpc/index.md b/src/content/developers/docs/apis/json-rpc/index.md
index c1aab360ed8..b503379cb43 100755
--- a/src/content/developers/docs/apis/json-rpc/index.md
+++ b/src/content/developers/docs/apis/json-rpc/index.md
@@ -19,7 +19,13 @@ Ethereum clients each may utilize different programming languages when implement
While you may choose to interact directly with Ethereum clients via the JSON-RPC API, there are often easier options for dapp developers. Many [JavaScript](/developers/docs/apis/javascript/#available-libraries) and [backend API](/developers/docs/apis/backend/#available-libraries) libraries exist to provide wrappers on top of the JSON-RPC API. With these libraries, developers can write intuitive, one-line methods in the programming language of their choice to initialize JSON-RPC requests (under the hood) that interact with Ethereum.
-## Spec {#spec}
+## Consensus client APIs {#consensus-clients}
+
+This page deals mainly with the JSON-RPC API used by Ethereum execution clients. However, consensus clients also have an RPC API that allows users to query information about the node, request Beacon blocks, Beacon state, and other consensus-related information directly from a node. This API is documented on the [Beacon API webpage](https://ethereum.github.io/beacon-APIs/#/).
+
+An internal API is also used for inter-client communication within a node - that is, it enables the consensus client and execution client to swap data. This is called the 'Engine API' and the specs are available on [Github](https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md).
+
+## Execution client spec {#spec}
[Read the full JSON-RPC API spec on GitHub](https://github.com/ethereum/execution-apis).
diff --git a/src/content/developers/docs/blocks/index.md b/src/content/developers/docs/blocks/index.md
index beddab24bac..736956f11bb 100644
--- a/src/content/developers/docs/blocks/index.md
+++ b/src/content/developers/docs/blocks/index.md
@@ -3,7 +3,6 @@ title: Blocks
description: An overview of blocks in the Ethereum blockchain – their data structure, why they're needed, and how they're made.
lang: en
sidebar: true
-preMergeBanner: true
---
Blocks are batches of transactions with a hash of the previous block in the chain. This links blocks together (in a chain) because hashes are cryptographically derived from the block data. This prevents fraud, because one change in any block in history would invalidate all the following blocks as all subsequent hashes would change and everyone running the blockchain would notice.
@@ -19,47 +18,117 @@ To ensure that all participants on the Ethereum network maintain a synchronized
![A diagram showing transaction in a block causing state changes](./tx-block.png)
_Diagram adapted from [Ethereum EVM illustrated](https://takenobu-hs.github.io/downloads/ethereum_evm_illustrated.pdf)_
-By spacing out commits, we give all network participants enough time to come to consensus: even though transaction requests occur dozens of times per second, blocks on Ethereum are committed approximately once every fifteen seconds.
+By spacing out commits, we give all network participants enough time to come to consensus: even though transaction requests occur dozens of times per second, blocks are only created and committed on Ethereum once every twelve seconds.
## How blocks work {#how-blocks-work}
To preserve the transaction history, blocks are strictly ordered (every new block created contains a reference to its parent block), and transactions within blocks are strictly ordered as well. Except in rare cases, at any given time, all participants on the network are in agreement on the exact number and history of blocks, and are working to batch the current live transaction requests into the next block.
-Once a block is put together (mined) by some miner on the network, it is propagated to the rest of the network; all nodes add this block to the end of their blockchain, and mining continues. The exact block-assembly (mining) process and commitment/consensus process is currently specified by Ethereum’s “proof-of-work” protocol.
+Once a block is put together by some validator on the network, it is propagated to the rest of the network; all nodes add this block to the end of their blockchain, and a new validator is selected to create the next block. The exact block-assembly process and commitment/consensus process is currently specified by Ethereum’s “proof-of-stake” protocol.
-### A visual demo {#a-visual-demo}
+## Proof-of-stake protocol {#proof-of-work-protocol}
-
+Proof-of-stake means the following:
-## Proof-of-work protocol {#proof-of-work-protocol}
+- Validating nodes have to stake 32 ETH into a deposit contract as collateral against bad behavior. This helps protect the network because provably dishonest activity leads to some or all of that stake being destroyed.
+- In every slot (spaced twelve seconds apart) a validator is randomly selected to be the block proposer. They bundle transactions together, execute them and determine a new 'state'. They wrap this information into a block and pass it around to other validators.
+- Other validators who hear about a new block re-execute the transactions to ensure they agree with the proposed change to the global state. Assuming the block is valid they add it to their own database.
+- If a validator hears about two conflicting blocks for the same slot they use their fork-choice algorithm to pick the one supported by the most staked ETH.
-Proof-of-work means the following:
-
-- Mining nodes have to spend a variable but substantial amount of energy, time, and computational power to produce a “certificate of legitimacy” for a block they propose to the network. This helps protect the network from spam/denial-of-service attacks, among other things, since certificates are expensive to produce.
-- Other miners who hear about a new block with a valid certificate of legitimacy must accept the new block as the canonical next block on the blockchain.
-- The exact amount of time needed for any given miner to produce this certificate is a random variable with high variance. This ensures that it is unlikely that two miners produce validations for a proposed next block simultaneously; when a miner produces and propagates a certified new block, they can be almost certain that the block will be accepted by the network as the canonical next block on the blockchain, without conflict (though there is a protocol for dealing with conflicts as well in the case that two chains of certified blocks are produced almost simultaneously).
-
-[More on mining](/developers/docs/consensus-mechanisms/pow/mining/)
+[More on proof-of-stake](/developers/docs/consensus-mechanisms/pos)
## What's in a block? {#block-anatomy}
-- `timestamp` – the time when the block was mined.
-- `blockNumber` – the length of the blockchain in blocks.
-- `baseFeePerGas` - the minimum fee per gas required for a transaction to be included in the block.
-- `difficulty` – the effort required to mine the block.
-- `mixHash` – a unique identifier for that block.
-- `parentHash` – the unique identifier for the block that came before (this is how blocks are linked in a chain).
-- `transactions` – the transactions included in the block.
-- `stateRoot` – the entire state of the system: account balances, contract storage, contract code and account nonces are inside.
-- `nonce` – a hash that, when combined with the mixHash, proves that the block has gone through [proof-of-work](/developers/docs/consensus-mechanisms/pow/).
+There is a lot of information contained within a block. At the highest level a block contains the following fields:
+
+```
+slot: the slot the block belongs to
+proposer_index: the ID of the validator proposing the block
+parent_root: the hash of the preceding block
+state_root: the root hash of the state object
+body: an object containing several fields, as defined below
+```
+
+The block `body` contains several fields of its own:
+
+```
+randao_reveal: a value used to select the next block proposer
+eth1_data: information about the deposit contract
+graffiti: arbitrary data used to tag blocks
+proposer_slashings: list of validators to be slashed
+attester_slashings: list of validators to be slashed
+attestations: list of attestations in favor of the current block
+deposits: list of new deposits to the deposit contract
+voluntary_exits: list of validators exiting the network
+sync_aggregate: subset of validators used to serve light clients
+execution_payload: transactions passed from the execution client
+```
+
+The `attestations` field contains a list of all the attestations in the block. Attestations have their own data type that contains several pieces of data. Each attestation contains:
+
+```
+aggregation_bits: a list of which validators participated in this attestation
+data: a container with multiple subfields
+signature: aggregate signature of all attesting validators
+```
+
+The `data` field in the `attestation` contains the following:
+
+```
+slot: the slot the attestation relates to
+index: indices for attesting validators
+beacon_block_root: the root hash of the Beacon block containing this object
+source: the last justified checkpoint
+target: the latest epoch boundary block
+```
+
+Executing the transactions in the `execution_payload` updates the global state. All clients re-execute the transactions in the `execution_payload` to ensure the new state matches that in the new block `state_root` field. This is how clients can tell that a new block is valid and safe to add to their blockchain. The `execution payload` itself is an object with several fields. There is also an `execution_payload_header` that contains important summary information about the execution data. These data structures are organized as follows:
+
+The `execution_payload_header` contains the following fields:
+
+```
+parent_hash: hash of the parent block
+fee_recipient: account address for paying transaction fees to
+state_root: root hash for the global state after applying changes in this block
+receipts_root: hash of the transaction receipts trie
+logs_bloom: data structure containign event logs
+prev_randao: value used in random validator selection
+block_number: the number of the current block
+gas_limit: maximum gas allowed in this block
+gas_used: the actual amount of gas used in this block
+timestamp: the block time
+extra_data: arbitrary additional data as raw bytes
+base_fee_per_gas: the base fee value
+block_hash: Hash of execution block
+transactions_root: root hash of the transactions in the payload
+```
+
+The `execution_payload` itself contains the following (notice this is idential to the header except that instead of the root hash of the transactions it includes the actual list of transactions:
+
+```
+parent_hash: hash of the parent block
+fee_recipient: account address for paying transaction fees to
+state_root: root hash for the global state after applying changes in this block
+receipts_root: hash of the transaction receipts trie
+logs_bloom: data structure containign event logs
+prev_randao: value used in random validator selection
+block_number: the number of the current block
+gas_limit: maximum gas allowed in this block
+gas_used: the actual amount of gas used in this block
+timestamp: the block time
+extra_data: arbitrary additional data as raw bytes
+base_fee_per_gas: the base fee value
+block_hash: Hash of execution block
+transactions: list of transactions to be executed
+```
## Block time {#block-time}
-Block time refers to the time it takes to mine a new block. In Ethereum, the average block time is between 12 to 14 seconds and is evaluated after each block. The expected block time is set as a constant at the protocol level and is used to protect the network's security when the miners add more computational power. The average block time gets compared with the expected block time, and if the average block time is higher, then the difficulty is decreased in the block header. If the average block time is smaller, then the difficulty in the block header will be increased.
+Block time refers to the time separating blocks. In Ethereum, time is divided up into twelve second units called 'slots'. In each slot a single validator is selected to propose a block. Assuming all validators are online and fully functional there will be a block in every slot, meaning the block time is 12s. However, occasionally validators might be offline when called to propose a block, meaning slots can sometimes go empty. This is different to proof-of-work based systems where block times are probabilistic and tuned by the mining difficulty.
## Block size {#block-size}
-A final important note is that blocks themselves are bounded in size. Each block has a target size of 15 million gas but the size of blocks will increase or decrease in accordance with network demands, up until the block limit of 30 million gas (2x target block size). The total amount of gas expended by all transactions in the block must be less than the block gas limit. This is important because it ensures that blocks can’t be arbitrarily large. If blocks could be arbitrarily large, then less performant full nodes would gradually stop being able to keep up with the network due to space and speed requirements.
+A final important note is that blocks themselves are bounded in size. Each block has a target size of 15 million gas but the size of blocks will increase or decrease in accordance with network demands, up until the block limit of 30 million gas (2x target block size). The total amount of gas expended by all transactions in the block must be less than the block gas limit. This is important because it ensures that blocks can’t be arbitrarily large. If blocks could be arbitrarily large, then less performant full nodes would gradually stop being able to keep up with the network due to space and speed requirements. The larger the block, the greater the computing power required to process them in time for the next slot. This is a centralizing force, which is resisted by capping block sizes.
## Further reading {#further-reading}
@@ -67,6 +136,6 @@ _Know of a community resource that helped you? Edit this page and add it!_
## Related topics {#related-topics}
-- [Mining](/developers/docs/consensus-mechanisms/pow/mining/)
- [Transactions](/developers/docs/transactions/)
- [Gas](/developers/docs/gas/)
+- [Proof-of-stake](/developers/docs/consensus-mechanisms/pos)
diff --git a/src/content/developers/docs/consensus-mechanisms/index.md b/src/content/developers/docs/consensus-mechanisms/index.md
index 7af78499c9e..1388f221c70 100644
--- a/src/content/developers/docs/consensus-mechanisms/index.md
+++ b/src/content/developers/docs/consensus-mechanisms/index.md
@@ -5,9 +5,7 @@ lang: en
sidebar: true
---
-When it comes to blockchains like Ethereum, which are, in essence, distributed databases, the network's nodes must reach an agreement on the network's current state. This agreement is achieved using consensus mechanisms.
-
-Although consensus mechanisms aren't directly related to building a dapp, understanding them will illuminate concepts relevant to you and your users' experience, like gas prices and transaction times.
+The term 'consensus mechanism' is often used colloquially to refer to 'proof-of-stake', 'proof-of-work' or 'proof-of-authority' protocols. However, these are just components in consensus mechanisms that protect against Sybil attacks. Consensus mechanisms are the complete stack of ideas, protocols and incentives that enable a distributed set of nodes to agree on the state of a blockchain.
## Prerequisites {#prerequisites}
@@ -15,31 +13,31 @@ To better understand this page, we recommend you first read our [introduction to
## What is consensus? {#what-is-consensus}
-By consensus, we mean that a general agreement has been reached. Consider a group of people going to the cinema. If there is not a disagreement on a proposed choice of film, then a consensus is achieved. In the extreme case the group will eventually split.
+By consensus, we mean that a general agreement has been reached. Consider a group of people going to the cinema. If there is no disagreement on a proposed choice of film, then a consensus is achieved. If there is disagreement, the group must have the means to decide which film to see. In extreme cases, the group will eventually split.
-In regards to blockchain, the process is formalized, and reaching consensus means that at least 51% of the nodes on the network agree on the next global state of the network.
+In regards to the Ethereum blockchain, the process is formalized, and reaching consensus means that at least 66% of the nodes on the network agree on the global state of the network.
## What is a consensus mechanism? {#what-is-a-consensus-mechanism}
-Consensus mechanisms (also known as consensus protocols or consensus algorithms) allow distributed systems (networks of computers) to work together and stay secure.
+The term consensus mechanism refers to the entire stack of protocols, incentives and ideas that allow a network of nodes to agree on the state of a blockchain.
-Consensus protocols and consensus algorithms are often used interchangeably. However, protocols and algorithms are different. A protocol is a set of rules defined in a standard that governs how a system and its many functioning parts operate and interact. Algorithms are like exact recipes on how to solve a problem or calculate a result.
+Ethereum uses a proof-of-stake-based consensus mechanism that derives its crypto-economic security from a set of rewards and penalties applied to capital locked by stakers. This incentive structure encourages individual stakers to operate honest validators, punishes those who don't, and creates an extremely high cost to attack the network.
-For decades, these mechanisms have been used to establish consensus among database nodes, application servers, and other enterprise infrastructure. In recent years, new consensus mechanisms have been invented to allow cryptoeconomic systems, such as Ethereum, to agree on the state of the network.
+Then, there is a protocol that governs how honest validators are selected to propose or validate blocks, process transactions and vote for their view of the head of the chain. In the rare situations where multiple blocks are in the same position near the head of the chain, there is a fork-choice mechanism that selects blocks that make up the 'heaviest' chain, measured by the number of validators that voted for the blocks weighted by their staked ether balance.
-A consensus mechanism in a cryptoeconomic system also helps prevent certain kinds of economic attacks. In theory, an attacker can compromise consensus by controlling 51% of the network. Consensus mechanisms are designed to make this "51% attack" unfeasible. Different mechanisms are engineered to solve this security problem in different ways.
+Some concepts are important to consensus that are not explicitly defined in code, such as the additional security offered by potential out-of-band social coordination as a last line of defense against attacks on the network.
-
+These components together form the consensus mechanism.
## Types of consensus mechanisms {#types-of-consensus-mechanisms}
-### Proof-of-work {#proof-of-work}
+### Proof-of-work based {#proof-of-work}
-Ethereum, like Bitcoin, currently uses a **proof-of-work (PoW)** consensus protocol.
+Like Bitcoin, Ethereum once used a **proof-of-work (PoW)** based consensus protocol.
#### Block creation {#pow-block-creation}
-Proof-of-work is done by [miners](/developers/docs/consensus-mechanisms/pow/mining/), who compete to create new blocks full of processed transactions. The winner shares the new block with the rest of the network and earns some freshly minted ETH. The race is won by the computer which is able to solve a math puzzle fastest – this produces the cryptographic link between the current block and the block that went before. Solving this puzzle is the work in "proof-of-work".
+Validators create blocks. One validator is randomly selected in each slot to be the block proposer. Their consensus client requests a bundle of transactions as an 'execution payload' from their paired execution client. They wrap this in consensus data to form a block, which they send to other nodes on the Ethereum network. This block production is rewarded in ETH. In rare cases when multiple possible blocks exist for a single slot, or nodes hear about blocks at different times, the fork choice algorithm picks the block that forms the chain with the greatest weight of attestations (where weight is the number of validators attesting scaled by their ETH balance).
#### Security {#pow-security}
@@ -47,9 +45,9 @@ The network is kept secure by the fact that you'd need 51% of the network's comp
More on [proof-of-work](/developers/docs/consensus-mechanisms/pow/)
-### Proof-of-stake {#proof-of-stake}
+### Proof-of-stake based {#proof-of-stake}
-Ethereum plans to upgrade to a **proof-of-stake (PoS)** consensus protocol.
+Ethereum now uses a **proof-of-stake (PoS)** based consensus protocol.
#### Block creation {#pos-block-creation}
@@ -57,7 +55,7 @@ Proof-of-stake is done by validators who have staked ETH to participate in the s
#### Security {#pos-security}
-A proof-of-stake system is kept secure by the fact that you'd need 51% of the total staked ETH to defraud the chain. And that your stake is slashed for malicious behaviour.
+A proof-of-stake system is secure crypto-economically because an attacker attempting to take control of the chain must destroy a massive amount of ETH. A system of rewards incentivizes individual stakers to behave honestly, and penalties disincentivize stakers from acting maliciously.
More on [proof-of-stake](/developers/docs/consensus-mechanisms/pos/)
@@ -69,15 +67,13 @@ Watch more on the different types of consensus mechanisms used on Ethereum:
### Sybil resistance & chain selection {#sybil-chain}
-Now technically, proof-of-work and proof-of-stake are not consensus protocols by themselves, but they are often referred to as such for simplicity. They are actually Sybil resistance mechanisms and block author selectors; they are a way to decide who is the author of the latest block. It's this Sybil resistance mechanism combined with a chain selection rule that makes up a true consensus mechanism.
+Proof-of-work and proof-of-stake alone are not consensus protocols, but they are often referred to as such for simplicity. They are actually Sybil resistance mechanisms and block author selectors; they are a way to decide who is the author of the latest block. Another important component is the chain selection (aka fork choice) algorithm that enables nodes to pick one single correct block at the head of the chain in scenarios where multiple blocks exist in the same position.
**Sybil resistance** measures how a protocol fares against a [Sybil attack](https://wikipedia.org/wiki/Sybil_attack). Sybil attacks are when one user or group pretends to be many users. Resistance to this type of attack is essential for a decentralized blockchain and enables miners and validators to be rewarded equally based on resources put in. Proof-of-work and proof-of-stake protect against this by making users expend a lot of energy or put up a lot of collateral. These protections are an economic deterrent to Sybil attacks.
-A **chain selection rule** is used to decide which chain is the "correct" chain. Ethereum and Bitcoin currently use the "longest chain" rule, which means that whichever blockchain is the longest will be the one the rest of the nodes accept as valid and work with. For proof-of-work chains, the longest chain is determined by the chain's total cumulative proof-of-work difficulty.
-
-The combination of proof-of-work and longest chain rule is known as "Nakamoto Consensus."
+A **chain selection rule** is used to decide which chain is the "correct" chain. Bitcoin uses the "longest chain" rule, which means that whichever blockchain is the longest will be the one the rest of the nodes accept as valid and work with. For proof-of-work chains, the longest chain is determined by the chain's total cumulative proof-of-work difficulty. Ethereum used to use the longest chain rule too; however, now that Etheruem runs on proof-of-stake it adopted an updated fork-choice algorithm that measures the 'weight' of the chain. The weight is the accumulated sum of validator votes, weighted by validator staked-ether balances.
-The [Beacon Chain](/upgrades/beacon-chain/) uses a consensus mechanism called [Casper the Friendly Finality Gadget](https://arxiv.org/abs/1710.09437), which is proof-of-stake based.
+Ethereum uses a consensus mechanism known as [Gasper](/developers/docs/consensus-mechanisms/pos/gasper/) that combines [Casper FFG proof-of-stake](https://arxiv.org/abs/1710.09437) with the [GHOST fork-choice rule](https://arxiv.org/abs/2003.03052).
## Further reading {#further-reading}
diff --git a/src/content/developers/docs/consensus-mechanisms/pos/index.md b/src/content/developers/docs/consensus-mechanisms/pos/index.md
index a54dbc96483..4cc9b880e5b 100644
--- a/src/content/developers/docs/consensus-mechanisms/pos/index.md
+++ b/src/content/developers/docs/consensus-mechanisms/pos/index.md
@@ -5,7 +5,7 @@ lang: en
sidebar: true
---
-Proof-of-stake (PoS) is the [consensus mechanism](/developers/docs/consensus-mechanisms/) that Ethereum will use after [The Merge](/upgrades/merge). Ethereum is moving off of [proof-of-work (PoW)](/developers/docs/consensus-mechanisms/pow/) to proof-of-stake because it is more secure, less energy-intensive, and better for implementing new scaling solutions. While it has always been the plan to transition to proof-of-stake, it is also more complex than proof-of-work, and refining the mechanism has taken years of research and development. The challenge now is to implement proof-of-stake on Ethereum Mainnet. This process is called ["The Merge"](/upgrades/merge/).
+Proof-of-stake (PoS) underlies Ethereum's [consensus mechanism](/developers/docs/consensus-mechanisms/). Ethereum switched on its proof-of-stake mechanism in 2022 because it is more secure, less energy-intensive, and better for implementing new scaling solutions compared to the previous [proof-of-work](/developers/docs/consensus-mechanisms/pow) architecture.
## Prerequisites {#prerequisites}
@@ -13,9 +13,9 @@ To better understand this page, we recommend you first read up on [consensus mec
## What is proof-of-stake (PoS)? {#what-is-pos}
-Proof-of-stake is a type of [consensus mechanism](/developers/docs/consensus-mechanisms/) used by blockchains to achieve distributed consensus. In proof-of-work, miners prove they have capital at risk by expending energy. In proof-of-stake, validators explicitly stake capital in the form of ether into a smart contract on Ethereum. This staked ether then acts as collateral that can be destroyed if the validator behaves dishonestly or lazily. The validator is then responsible for checking that new blocks propagated over the network are valid and occasionally creating and propagating new blocks themselves.
+Proof-of-stake underlies certain [consensus mechanisms](/developers/docs/consensus-mechanisms/) used by blockchains to achieve distributed consensus. In proof-of-work, miners prove they have capital at risk by expending energy. Ethereum uses proof-of-stake, where validators explicitly stake capital in the form of ETH into a smart contract on Ethereum. This staked ETH then acts as collateral that can be destroyed if the validator behaves dishonestly or lazily. The validator is then responsible for checking that new blocks propagated over the network are valid and occasionally creating and propagating new blocks themselves.
-Proof-of-stake comes with a number of improvements to the proof-of-work system:
+Proof-of-stake comes with a number of improvements to the now-deprecated proof-of-work system:
- better energy efficiency – there is no need to use lots of energy on proof-of-work computations
- lower barriers to entry, reduced hardware requirements – there is no need for elite hardware to stand a chance of creating new blocks
@@ -26,17 +26,17 @@ Proof-of-stake comes with a number of improvements to the proof-of-work system:
## Validators {#validators}
-To participate as a validator, a user must deposit 32 ETH into the deposit contract and run three separate pieces of software: an execution client, a consensus client, and a validator. On depositing their ether, the user joins an activation queue that limits the rate of new validators joining the network. Once activated, validators receive new blocks from peers on the Ethereum network. The transactions delivered in the block are re-executed, and the block signature is checked to ensure the block is valid. The validator then sends a vote (called an attestation) in favor of that block across the network.
+To participate as a validator, a user must deposit 32 ETH into the deposit contract and run three separate pieces of software: an execution client, a consensus client, and a validator. On depositing their ETH, the user joins an activation queue that limits the rate of new validators joining the network. Once activated, validators receive new blocks from peers on the Ethereum network. The transactions delivered in the block are re-executed, and the block signature is checked to ensure the block is valid. The validator then sends a vote (called an attestation) in favor of that block across the network.
Whereas under proof-of-work, the timing of blocks is determined by the mining difficulty, in proof-of-stake, the tempo is fixed. Time in proof-of-stake Ethereum is divided into slots (12 seconds) and epochs (32 slots). One validator is randomly selected to be a block proposer in every slot. This validator is responsible for creating a new block and sending it out to other nodes on the network. Also in every slot, a committee of validators is randomly chosen, whose votes are used to determine the validity of the block being proposed.
## Finality {#finality}
-A transaction has "finality" in distributed networks when it's part of a block that can't change without a significant amount of ether getting burned. On proof-of-stake Ethereum, this is managed using "checkpoint" blocks. The first block in each epoch is a checkpoint. Validators vote for pairs of checkpoints that it considers to be valid. If a pair of checkpoints attracts votes representing at least two-thirds of the total staked ether, the checkpoints are upgraded. The more recent of the two (target) becomes "justified". The earlier of the two is already justified because it was the "target" in the previous epoch. Now it is upgraded to "finalized". To revert a finalized block, an attacker would commit to losing at least one-third of the total supply of staked ether (currently around $10,000,000,000). The exact reason for this is explained [in this Ethereum Foundation blog post](https://blog.ethereum.org/2016/05/09/on-settlement-finality/). Since finality requires a two-thirds majority, an attacker could prevent the network from reaching finality by voting with one-third of the total stake. There is a mechanism to defend against this: the [inactivity leak](https://arxiv.org/pdf/2003.03052.pdf). This activates whenever the chain fails to finalize for more than four epochs. The inactivity leak bleeds away the staked ether from validators voting against the majority, allowing the majority to regain a two-thirds majority and finalize the chain.
+A transaction has "finality" in distributed networks when it's part of a block that can't change without a significant amount of ETH getting burned. On proof-of-stake Ethereum, this is managed using "checkpoint" blocks. The first block in each epoch is a checkpoint. Validators vote for pairs of checkpoints that it considers to be valid. If a pair of checkpoints attracts votes representing at least two-thirds of the total staked ETH, the checkpoints are upgraded. The more recent of the two (target) becomes "justified". The earlier of the two is already justified because it was the "target" in the previous epoch. Now it is upgraded to "finalized". To revert a finalized block, an attacker would commit to losing at least one-third of the total supply of staked ETH. The exact reason for this is explained in this [Ethereum Foundation blog post](https://blog.ethereum.org/2016/05/09/on-settlement-finality/). Since finality requires a two-thirds majority, an attacker could prevent the network from reaching finality by voting with one-third of the total stake. There is a mechanism to defend against this: the [inactivity leak](https://arxiv.org/pdf/2003.03052.pdf). This activates whenever the chain fails to finalize for more than four epochs. The inactivity leak bleeds away the staked ETH from validators voting against the majority, allowing the majority to regain a two-thirds majority and finalize the chain.
## Crypto-economic security {#crypto-economic-security}
-Running a validator is a commitment. The validator is expected to maintain sufficient hardware and connectivity to participate in block validation and proposal. In return, the validator is paid in ether (their staked balance increases). On the other hand, participating as a validator also opens new avenues for users to attack the network for personal gain or sabotage. To prevent this, validators miss out on ether rewards if they fail to participate when called upon, and their existing stake can be destroyed if they behave dishonestly. There are two primary behaviors that can be considered dishonest: proposing multiple blocks in a single slot (equivocating) and submitting contradictory attestations. The amount of ether slashed depends on how many validators are also being slashed at around the same time. This is known as the ["correlation penalty"](https://arxiv.org/pdf/2003.03052.pdf), and it can be minor (~1% stake for a single validator slashed on their own) or can result in 100% of the validator's stake getting destroyed (mass slashing event). It is imposed halfway through a forced exit period that begins with an immediate penalty (up to 0.5 ETH) on Day 1, the correlation penalty on Day 18, and finally, ejection from the network on Day 36. They receive minor attestation penalties every day because they are present on the network but not submitting votes. This all means a coordinated attack would be very costly for the attacker.
+Running a validator is a commitment. The validator is expected to maintain sufficient hardware and connectivity to participate in block validation and proposal. In return, the validator is paid in ETH (their staked balance increases). On the other hand, participating as a validator also opens new avenues for users to attack the network for personal gain or sabotage. To prevent this, validators miss out on ETH rewards if they fail to participate when called upon, and their existing stake can be destroyed if they behave dishonestly. There are two primary behaviors that can be considered dishonest: proposing multiple blocks in a single slot (equivocating) and submitting contradictory attestations. The amount of ETH slashed depends on how many validators are also being slashed at around the same time. This is known as the ["correlation penalty"](https://arxiv.org/pdf/2003.03052.pdf), and it can be minor (~1% stake for a single validator slashed on their own) or can result in 100% of the validator's stake getting destroyed (mass slashing event). It is imposed halfway through a forced exit period that begins with an immediate penalty (up to 0.5 ETH) on Day 1, the correlation penalty on Day 18, and finally, ejection from the network on Day 36. They receive minor attestation penalties every day because they are present on the network but not submitting votes. This all means a coordinated attack would be very costly for the attacker.
## Fork choice {#fork-choice}
@@ -44,7 +44,7 @@ When the network performs optimally and honestly, there is only ever one new blo
## Proof-of-stake and security {#pos-and-security}
-The threat of a [51% attack](https://www.investopedia.com/terms/1/51-attack.asp) still exists on proof-of-stake as it does on proof-of-work, but it's even riskier for the attackers. A attacker would need 51% of the staked ETH (about $15,000,000,000 USD). They could then use their own attestations to ensure their preferred fork was the one with the most accumulated attestations. The 'weight' of accumulated attestations is what consensus clients use to determine the correct chain, so this attacker would be able to make their fork the canonical one. However, a strength of proof-of-stake over proof-of-work is that the community has flexibility in mounting a counter-attack. For example, the honest validators could decide to keep building on the minority chain and ignore the attacker's fork while encouraging apps, exchanges, and pools to do the same. They could also decide to forcibly remove the attacker from the network and destroy their staked ether. These are strong economic defenses against a 51% attack.
+The threat of a [51% attack](https://www.investopedia.com/terms/1/51-attack.asp) still exists on proof-of-stake as it does on proof-of-work, but it's even riskier for the attackers. A attacker would need 51% of the staked ETH. They could then use their own attestations to ensure their preferred fork was the one with the most accumulated attestations. The 'weight' of accumulated attestations is what consensus clients use to determine the correct chain, so this attacker would be able to make their fork the canonical one. However, a strength of proof-of-stake over proof-of-work is that the community has flexibility in mounting a counter-attack. For example, the honest validators could decide to keep building on the minority chain and ignore the attacker's fork while encouraging apps, exchanges, and pools to do the same. They could also decide to forcibly remove the attacker from the network and destroy their staked ETH. These are strong economic defenses against a 51% attack.
51% attacks are just one flavor of malicious activity. Bad actors could attempt long-range attacks (although the finality gadget neutralizes this attack vector), short range 'reorgs' (although proposer boosting and attestation deadlines mitigate this), bouncing and balancing attacks (also mitigated by proposer boosting, and these attacks have anyway only been demonstrated under idealized network conditions) or avalanche attacks (neutralized by the fork choice algorithms rule of only considering the latest message).
@@ -57,7 +57,7 @@ Overall, proof-of-stake, as it is implemented on Ethereum, has been demonstrated
| Staking makes it easier for individuals to participate in securing the network, promoting decentralization. validator node can be run on a normal laptop. Staking pools allow users to stake without having 32 ETH. | Proof-of-stake is younger and less battle-tested compared to proof-of-work |
| Staking is more decentralized. Economies of scale do not apply in the same way that they do for PoW mining. | Proof-of-stake is more complex to implement than proof-of-work |
| Proof-of-stake offers greater crypto-economic security than proof-of-work | Users need to run three pieces of software to participate in Ethereum's proof-of-stake. |
-| Less issuance of new ether is required to incentivize network participants | |
+| Less issuance of new ETH is required to incentivize network participants | |
## Further reading {#further-reading}
@@ -67,6 +67,7 @@ Overall, proof-of-stake, as it is implemented on Ethereum, has been demonstrated
- [The Beacon Chain Ethereum 2.0 explainer you need to read first](https://ethos.dev/beacon-chain/) _Ethos.dev_
- [Why Proof of Stake (Nov 2020)](https://vitalik.ca/general/2020/11/06/pos2020.html) _Vitalik Buterin_
- [Proof of Stake: How I Learned to Love Weak Subjectivity](https://blog.ethereum.org/2014/11/25/proof-stake-learned-love-weak-subjectivity/) _Vitalik Buterin_
+- [Proof-of-stake Ethereum attack and defense](https://mirror.xyz/jmcook.eth/YqHargbVWVNRQqQpVpzrqEQ8IqwNUJDIpwRP7SS5FXs)
- [A Proof of Stake Design Philosophy](https://medium.com/@VitalikButerin/a-proof-of-stake-design-philosophy-506585978d51) _Vitalik Buterin_
## Related topics {#related-topics}
diff --git a/src/content/developers/docs/consensus-mechanisms/pos/keys/index.md b/src/content/developers/docs/consensus-mechanisms/pos/keys/index.md
new file mode 100644
index 00000000000..54a0e76e22d
--- /dev/null
+++ b/src/content/developers/docs/consensus-mechanisms/pos/keys/index.md
@@ -0,0 +1,89 @@
+---
+title: Keys in proof-of-stake Ethereum
+description: An explanation of keys used in Ethereum's proof-of-stake consensus mechanism
+lang: en
+sidebar: true
+---
+
+Ethereum secures user's assets using public-private key cryptography. The public key is used as the basis for an Ethereum address—that is, it is visible to the general public and used as a unique identifier. The private (or 'secret') key should only ever be accessible to an account owner. The private key is used to 'sign' transactions and data so that cryptography can prove that the holder approves some action of a specific private key.
+
+Ethereum's keys are generated using [elliptic-curve cryptography](https://en.wikipedia.org/wiki/Elliptic-curve_cryptography).
+
+However, when Ethereum switched from [proof-of-work](/developers/docs/consensus-mechanisms/pow) to [proof-of-stake](/developers/docs/consensus-mechanisms/pos) a new type of key was added to Ethereum. The original keys still work exactly the same as before—there were no changes to the elliptic-curve-based keys securing accounts. However, users needed a new type of key for participating in proof-of-stake by staking ETH and running validators. This need arose from scalability challenges associated with many messages passing between large numbers of validators that required a cryptographic method that could easily be aggregated to reduce the amount of communication required for the network to come to consensus.
+
+This new type of key uses the [Boneh-Lyn-Shacham (BLS) signature scheme](https://wikipedia.org/wiki/BLS_digital_signature). BLS enables a very efficient aggregation of signatures but also allows reverse engineering of aggregated individual validator keys and is ideal for managing actions between validators.
+
+## The two types of validator keys {#two-types-of-keys}
+
+Before the switch to proof-of-stake, Ethereum users only had a single elliptic-curve-based private key to access their funds. With the introduction of proof-of-stake, users that wished to be solo stakers also required a **validator key** and a **withdrawal key**.
+
+### The validator key {#validator-key}
+
+The validator signing key consists of two elements:
+
+- Validator **private** key
+- Validator **public** key
+
+The purpose of the validator private key is to sign on-chain operations such as block proposals and attestations. Because of this, these keys must be held in a hot wallet.
+
+This flexibility has the advantage of moving validator signing keys very quickly from one device to another, however, if they have gotten lost or stolen, a thief may be able to **act maliciously** in a few ways:
+
+- Get the validator slashed by:
+ - Being a proposer and signing two different beacon blocks for the same slot
+ - Being an attester and signing an attestation that "surrounds" another one
+ - Being an attester and signing two different attestations having the same target
+- Force a voluntary exit, which stops the validator from staking, and grants access to its ETH balance to the withdrawal key owner
+
+The **validator public key** is included in the transaction data when a user deposits ETH to the staking deposit contract. This is known as the _deposit data_ and it allows Ethereum to identify the validator.
+
+### The withdrawal key {#withdrawal-key}
+
+The withdrawal key will be required to move the validator balance after this is enabled in the upcoming Shanghai upgrade. Just like the validator keys, the withdrawal keys also consist of two components:
+
+- Withdrawal **private** key
+- Withdrawal **public** key
+
+Losing this key means losing access to the validator balance. However, the validator can still sign attestations and blocks since these actions require the validator's private key, but there is little to no incentive if the withdrawal keys are lost.
+
+Separating the validator keys from the Ethereum account keys enables multiple validators to be run by a single user.
+
+![validator key schematic](validator-key-schematic.png)
+
+## Deriving keys from a seed phrase {#deriving-keys-from-seed}
+
+If every 32 ETH staked required a new set of 2 completely independent keys, key management would quickly become unwieldy, especially for users running multiple validators. Instead, multiple validator keys can be derived from a single common secret and storing that single secret allows access to multiple validator keys.
+
+[Mnemonics](https://en.bitcoinwiki.org/wiki/Mnemonic_phrase) and paths are prominent features that users often encounter when [they access](https://ethereum.stackexchange.com/questions/19055/what-is-the-difference-between-m-44-60-0-0-and-m-44-60-0) their wallets. The mnemonic is a sequence of words that act as an initial seed for a private key. When combined with additional data, the mnemonic generates a hash known as the 'master key'. This can be thought of as the root of a tree. Branches from this root can then be derived using a hierarchical path so that child nodes can exist as combinations of their parent node's hash and their index in the tree. Read about [BIP-32](https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki) and [BIP-19](https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki) standards for mnemonic-based key generation.
+
+These paths have the following structure, which will be familiar to users who have interacted with hardware wallets:
+
+```
+m/44'/60'/0'/0`
+```
+
+The slashes in this path separate components of the private key as follows:
+
+```
+master_key / purpose / coin_type / account / change / address_index
+```
+
+This logic enables users to attach as many validators as possible to a single **mnemonic phrase** because the tree root can be common, and differentiation can happen at the branches. The user can **derive any number of keys** from the mnemonic phrase.
+
+```
+ [m / 0]
+ /
+ /
+[m] - [m / 1]
+ \
+ \
+ [m / 2]
+```
+
+Each branch is separated by a `/` so `m/2` means start with the master key and follow branch 2. In the schematic below a single mnemonic phrase is used to store three withdrawal keys, each with two associated validators.
+
+![validator key logic](multiple-keys.png)
+
+## Further reading {#further-reading}
+
+- [Ethereum Foundation blog post by Carl Beekhuizen](https://blog.ethereum.org/2020/05/21/keys/)
+- [EIP-2333 BLS12-381 key generation](https://eips.ethereum.org/EIPS/eip-2333)
diff --git a/src/content/developers/docs/consensus-mechanisms/pos/keys/multiple-keys.png b/src/content/developers/docs/consensus-mechanisms/pos/keys/multiple-keys.png
new file mode 100644
index 00000000000..f75b39ab093
Binary files /dev/null and b/src/content/developers/docs/consensus-mechanisms/pos/keys/multiple-keys.png differ
diff --git a/src/content/developers/docs/consensus-mechanisms/pos/keys/validator-key-schematic.png b/src/content/developers/docs/consensus-mechanisms/pos/keys/validator-key-schematic.png
new file mode 100644
index 00000000000..83dcbeaddee
Binary files /dev/null and b/src/content/developers/docs/consensus-mechanisms/pos/keys/validator-key-schematic.png differ
diff --git a/src/content/developers/docs/consensus-mechanisms/pos/rewards-and-penalties/index.md b/src/content/developers/docs/consensus-mechanisms/pos/rewards-and-penalties/index.md
new file mode 100644
index 00000000000..a761c0de92c
--- /dev/null
+++ b/src/content/developers/docs/consensus-mechanisms/pos/rewards-and-penalties/index.md
@@ -0,0 +1,92 @@
+---
+title: Proof-of-stake rewards and penalties
+description: Learn about the in-protocol incentives in proof-of-stake Ethereum.
+lang: en
+sidebar: true
+---
+
+Ethereum is secured using its native cryptocurrency, ether (ETH). Node operators that wish to participate in validating blocks and identifying the head of the chain deposit ether into a smart contract on Ethereum. They are then paid in ether to run validator software that checks the validity of new blocks received over the peer-to-peer network and apply the fork-choice algorithm to identify the head of the chain.
+
+There are two primary roles for a validator: 1) checking new blocks and “attesting” to them if they are valid, 2) proposing new blocks when selected at random from the total validator pool. If the validator fails to do either of these tasks when asked they miss out on an ether payout. Validators are also sometimes tasked with signature aggregation and participating in sync committees.
+
+There are also some actions that are very difficult to do accidentally and signify some malicious intent, such as proposing multiple blocks for the same slot or attesting to multiple blocks for the same slot. These are “slashable” behaviors that result in the validator having some amount of ether (up to 1 ETH) burned before the validator is removed from the network, which takes 36 days. The slashed validator’s ether slowly drains away across the exit period, but on Day 18 they receive a “correlation penalty” which is larger when more validators are slashed around the same time. The Beacon Chain’s incentive structure therefore pays for honesty and punishes bad actors.
+
+All rewards and penalties are applied once per epoch.
+
+Read on for more details...
+
+## Rewards and penalties {#rewards}
+
+### Rewards {#rewards}
+
+Validators receive rewards when they make votes that are consistent with the majority of other validators, when they propose blocks, and when they participate in sync committees. The value of the rewards in each epoch are calculated from a `base_reward`. This is the base unit that other rewards are calculated from. The `base_reward` represents the average reward received by a validator under optimal conditions per epoch. This is calculated from the validator's effective balance and the total number of active validators as follows:
+
+```
+base_reward = effective_balance * (base_reward_factor / (base_rewards_per_epoch * sqrt(sum(active_balance))))
+```
+
+where `base_reward_factor` is 64, `base_rewards_per_epoch` is 4 and `sum(active balance)` is the total staked ether across all active validators.
+
+This means the base reward is proportional to the validator's effective balance and inversely proportional to the number of validators on the network. The more validators, the greater the overall issuance (as `sqrt(N)` but the smaller the `base_reward` per validator (as `1/sqrt(N)`). These factors influence the APR for a staking node. Read the rationale for this in [Vitalik's notes](https://notes.ethereum.org/@vbuterin/rkhCgQteN?type=view#Base-rewards).
+
+The total reward is then calculated as the sum of five components that each have a weighting that determines how much each component adds to the total reward. The components are:
+
+```
+1. source vote: the validator has made a timely vote for the correct source checkpoint
+2. target vote: the validator has made a timely vote for the correct target checkpoint
+3. head vote: the validator has made a timely vote for the correct head block
+4. sync committee reward: the validator has participated in a sync committee
+5. proposer reward: the validator has proposed a block in the correct slot
+```
+
+The weightings for each component are as follows:
+
+```
+TIMELY_SOURCE_WEIGHT uint64(14)
+TIMELY_TARGET_WEIGHT uint64(26)
+TIMELY_HEAD_WEIGHT uint64(14)
+SYNC_REWARD_WEIGHT uint64(2)
+PROPOSER_WEIGHT uint64(8)
+```
+
+These weights sum to 64. The reward is calculated as the sum of the applicable weights divided by 64. A validator that has made timely source, target and head votes, proposed a block and participated in a sync committee could receive `64/64 * base_reward == base_reward`. However, a validator is not usually a block proposer, so their maximum reward is `64-8 /64 * base_reward == 7/8 * base_reward`. Validators that are neither block proposers nor in a sync committee can receive `64-8-2 / 64 * base_reward == 6.75/8 * base_reward`.
+
+An additional reward is added to incentivize rapid attestations. This is the `inclusion_delay_reward`. This has a value equal to the `base_reward` multiplied by `1/delay` where `delay` is the number of slots separating the block proposal and attestation. For example, if the attestation is submitted within one slot of the block proposal the attestor receives `base_reward * 1/1 == base_reward`. If the attestation arrives in the next slot, the attestor received `base_reward * 1/2` and so on.
+
+Block proposers receive `8 / 64 * base_reward` for **each valid attestation** included in the block, so the actual value of the reward scales with the number of attesting validators. Block proposers can also increase their reward by including evidence of misbehavior by other validators in their proposed block. These rewards are the "carrots" that encourage validator honesty. A block proposer which includes slashing will be rewarded with the `slashed_validators_effective_balance / 512`.
+
+### Penalties {#penalties}
+
+So far we have considered perfectly well-behaved validators, but what about validators that do not make timely head, source and target votes or do so slowly?
+
+The penalties for missing the head, target and source votes are equal to the rewards the attestor would have received had they submitted them. This means that instead of having the reward added to their balance, they have an equal value removed from their balance. There is no penalty associated with the `inclusion_delay` - the reward will simply not be added to the validator's balance. There is no penalty for failing to propose a block.
+
+Read more about rewards and penalties in the [consensus specs](https://github.com/ethereum/consensus-specs/blob/dev/specs/altair/beacon-chain.md). Rewards and penalties were adjusted in the Bellatrix upgrade - watch Danny Ryan and Vitalik discuss this in this [Peep an EIP video](https://www.youtube.com/watch?v=iaAEGs1DMgQ).
+
+## Slashing {#slashing}
+
+Slashing is a more severe action that results in the forceful removal of a validator from the network and an associated loss of their staked ether. There are three ways a validator can be slashed, all of which amount to the dishonest proposal or attestation of blocks:
+
+- By proposing and signing two different blocks for the same slot
+- By attesting to a block that "surrounds" another one (effectively changing history)
+- By "double voting" by attesting to two candidates for the same block
+
+If these actions are detected, the validator is slashed. This means that 1/32 of their staked ether (up to a maximum of 1 ether) is immediately burned, then a 36 day removal period begins. During this removal period the validators stake gradually bleeds away. At the mid-point (Day 18) an additional penalty is applied whose magnitude scales with the total staked ether of all slashed validators in the 36 days prior to slashing event. This means that when more validators are slashed, the magnitude of the slash increases. The maximum slash is the full effective balance of all slashed validators (i.e. if there are lots of validators being slashed they could lose their entire stake). On the other hand, a single, isolated slashing event only burns a small portion of the validator's stake. This midpoint penalty that scales with the number of slashed validators is called the "correlation penalty".
+
+## Inactivity Leak {#inactivity-leak}
+
+If the Beacon Chain has gone more than four epochs without finalizing, an emergency protocol called the "inactivity leak" is activated. The ultimate aim of the inactivity leak is to create the conditions required for the chain to recover finality. As explained above, finality requires a 2/3 majority of the total staked ether to agree on source and target checkpoints. If validators representing more than 1/3 of the total validators go offline or fail to submit correct attestations then it is not possible for a 2/3 supermajority to finalize checkpoints. The inactivity leak lets the stake belonging to the inactive validators gradually bleed away until they control less than 1/3 of the total stake, allowing the remaining active validators finalize the chain. However large the pool of inactive validators, the remaining active validators will eventually control >2/3 of the stake. The loss of stake is a strong incentive for inactive validators to reactivate as soon as possible! An inactivity leak scenario was encountered on the Medalla testnet when < 66% of active validators were able to come to consensus on the current head of the blockchain. The inactivity leak was activated and finality was eventually regained!
+
+The reward, penalty and slashing design of the Beacon Chain encourages individual validators to behave correctly. However, from these design choices emerges a system that strongly incentivizes equal distribution of validators across multiple clients, and should strongly disincentivize single-client dominance.
+
+## Further Reading {#further-reading}
+
+[Upgrading Ethereum: The incentive layer](https://eth2book.info/altair/part2/incentives)
+[Incentives in Ethereum's hybrid Casper protocol](https://arxiv.org/pdf/1903.04205.pdf)
+[Rewards and Penalties on Ethereum 2.0](https://consensys.net/blog/codefi/rewards-and-penalties-on-ethereum-20-phase-0/)
+[Vitalik's annotated spec](https://github.com/ethereum/annotated-spec/blob/master/phase0/beacon-chain.md#rewards-and-penalties-1)
+[Eth2 Slashing Prevention Tips](https://medium.com/prysmatic-labs/eth2-slashing-prevention-tips-f6faa5025f50)
+
+_Sources_
+_[https://consensys.net/blog/codefi/rewards-and-penalties-on-ethereum-20-phase-0/](https://consensys.net/blog/codefi/rewards-and-penalties-on-ethereum-20-phase-0/)_
+_[https://benjaminion.xyz/eth2-annotated-spec/phase0/beacon-chain/](https://benjaminion.xyz/eth2-annotated-spec/phase0/beacon-chain/)_
diff --git a/src/content/developers/docs/consensus-mechanisms/pow/index.md b/src/content/developers/docs/consensus-mechanisms/pow/index.md
index 49694e7776b..b5206c8a348 100644
--- a/src/content/developers/docs/consensus-mechanisms/pow/index.md
+++ b/src/content/developers/docs/consensus-mechanisms/pow/index.md
@@ -3,12 +3,13 @@ title: Proof-of-work (PoW)
description: An explanation of the proof-of-work consensus protocol and its role in Ethereum.
lang: en
sidebar: true
-incomplete: true
---
-Ethereum, like Bitcoin, currently uses a consensus protocol called **[Proof-of-work (PoW)](https://wikipedia.org/wiki/Proof_of_work)**. This allows the nodes of the Ethereum network to agree on the state of all information recorded on the Ethereum blockchain and prevents certain kinds of economic attacks.
+The Ethereum network began by using a consensus mechanism that involved **[Proof-of-work (PoW)](/developers/docs/consensus-mechanisms/pow)**. This allowed the nodes of the Ethereum network to agree on the state of all information recorded on the Ethereum blockchain and prevented certain kinds of economic attacks. However, Ethereum switched off proof-of-work in 2022 and started using [proof-of-stake](/developers/docs/consensus-mechanisms/pos) instead.
-Over the next year, proof-of-work will be phased out in favour of **[Proof-of-stake (PoS)](/developers/docs/consensus-mechanisms/pos)**. The transition to proof-of-stake will also phase out mining from Ethereum. [More on The Merge.](/upgrades/merge/)
+
+ Proof-of-work has now been deprecated. Ethereum no longer uses proof-of-work as part of its consensus mechanism. Instead, it uses proof-of-stake. Read more on proof-of-stake and staking.
+
## Prerequisites {#prerequisites}
@@ -16,63 +17,59 @@ To better understand this page, we recommend you first read up on [transactions]
## What is Proof-of-work (PoW)? {#what-is-pow}
-Proof-of-work is the mechanism that allows the decentralized Ethereum network to come to consensus, or agree on things like account balances and the order of transactions. This prevents users from "double spending" their coins and ensures that the Ethereum chain is tremendously difficult to attack or manipulate.
+Nakamoto consensus, which utilizes proof-of-work, is the mechanism that once allowed the decentralized Ethereum network to come to consensus (i.e. all nodes agree) on things like account balances and the order of transactions. This prevented users from "double spending" their coins and ensured that the Ethereum chain was tremendously difficult to attack or manipulate. These security properties now come from proof-of-stake instead using the consensus mechanism known as [Gasper](/developers/docs/consensus-mechanisms/pos/gasper/).
## Proof-of-work and mining {#pow-and-mining}
-Proof-of-work is the underlying algorithm that sets the difficulty and rules for the work miners do. Mining is the "work" itself. It's the act of adding valid blocks to the chain. This is important because the chain's length helps the network follow the correct Ethereum chain and understand Ethereum's current state. The more "work" done, the longer the chain, and the higher the block number, the more certain the network can be of the current state of things.
+Proof-of-work is the underlying algorithm that sets the difficulty and rules for the work miners do on proof-of-work blockchains. Mining is the "work" itself. It's the act of adding valid blocks to the chain. This is important because the chain's length helps the network follow the correct fork of the blockchain. The more "work" done, the longer the chain, and the higher the block number, the more certain the network can be of the current state of things.
[More on mining](/developers/docs/consensus-mechanisms/pow/mining/)
-## How does Ethereum's proof-of-work work? {#how-it-works}
+## How did Ethereum's proof-of-work work? {#how-it-works}
-Ethereum transactions are processed into blocks. Each block has a:
+Ethereum transactions are processed into blocks. In the now-deprecated proof-of-work Ethereum, each block contained:
- block difficulty – for example: 3,324,092,183,262,715
- mixHash – for example: `0x44bca881b07a6a09f83b130798072441705d9a665c5ac8bdf2f39a3cdf3bee29`
- nonce – for example: `0xd3ee432b4fb3d26b`
-This block data is directly related to proof-of-work.
+This block data was directly related to proof-of-work.
### The work in proof-of-work {#the-work}
-The proof-of-work protocol, Ethash, requires miners to go through an intense race of trial and error to find the nonce for a block. Only blocks with a valid nonce can be added to the chain.
+The proof-of-work protocol, Ethash, required miners to go through an intense race of trial and error to find the nonce for a block. Only blocks with a valid nonce could be added to the chain.
-When racing to create a block, a miner will repeatedly put a dataset, that you can only get from downloading and running the full chain (as a miner does), through a mathematical function. The dataset gets used to generate a mixHash below a target nonce, as dictated by the block difficulty. The best way to do this is through trial and error.
+When racing to create a block, a miner repeatedly put a dataset, that could only be obtained by downloading and running the full chain (as a miner does), through a mathematical function. The dataset was used to generate a mixHash below a target that is dictated by the block difficulty. The best way to do this is through trial and error.
-The difficulty determines the target for the hash. The lower the target, the smaller the set of valid hashes. Once generated, this is incredibly easy for other miners and clients to verify. Even if one transaction were to change, the hash would be completely different, signalling fraud.
+The difficulty determined the target for the hash. The lower the target, the smaller the set of valid hashes. Once generated, this was incredibly easy for other miners and clients to verify. Even if one transaction were to change, the hash would be completely different, signalling fraud.
-Hashing makes fraud easy to spot. But proof-of-work as a process is also a big deterrent to attacking the chain.
+Hashing makes fraud easy to spot. But proof-of-work as a process was also a big deterrent to attacking the chain.
### Proof-of-work and security {#security}
-Miners are incentivised to do this work on the main Ethereum chain. There is little incentive for a subset of miners to start their own chain – it undermines the system. Blockchains rely on having a single state as a source of truth. And users will always choose the longest or "heaviest" chain.
+Miners were incentivized to do this work on the main Ethereum chain. There was little incentive for a subset of miners to start their own chain—it undermines the system. Blockchains rely on having a single state as a source of truth.
-The objective of proof-of-work is to extend the chain. The longest chain is most believable as the valid one because it's had the most computational work done. Within Ethereum's PoW system, it's nearly impossible to create new blocks that erase transactions, create fake ones, or maintain a second chain. That's because a malicious miner would need to always solve the block nonce faster than everyone else.
+The objective of proof-of-work was to extend the chain. The longest chain was most believable as the valid one because it had the most computational work done to generate it. Within Ethereum's PoW system, it was nearly impossible to create new blocks that erase transactions, create fake ones, or maintain a second chain. That's because a malicious miner would have needed to always solve the block nonce faster than everyone else.
-To consistently create malicious yet valid blocks, you'd need over 51% of the network mining power to beat everyone else. You'd need a lot of computing power to be able to do this amount of "work". And the energy spent might even outweigh the gains you'd make in an attack.
+To consistently create malicious yet valid blocks, a malicious miner would have needed over 51% of the network mining power to beat everyone else. That amount of "work" requires a lot of expensive computing power and the energy spent might even have outweighed the gains made in an attack.
### Proof-of-work economics {#economics}
-Proof-of-work is also responsible for issuing new currency into the system and incentivizing miners to do the work.
+Proof-of-work was also responsible for issuing new currency into the system and incentivizing miners to do the work.
-Miners who successfully create a block get rewarded with two freshly minted ETH but no longer receive all the transaction fees, as the base fee gets burned, while the tip and block reward goes to the miner. A miner may also get 1.75 ETH for an uncle block. Uncle blocks are valid blocks created by a miner practically at the same time as another miner mined the successful block. Uncle blocks usually happen due to network latency.
+Since the [Constantinople upgrade](/history/#constantinople), miners who successfully create a block were rewarded with two freshly minted ETH and part of the transaction fees. Ommer blocks also compensated 1.75 ETH. Ommer blocks were valid blocks created by a miner practically at the same time as another miner created the canonical block, which was ultimately determined by which chain was built on top of first. Ommer blocks usually happened due to network latency.
## Finality {#finality}
A transaction has "finality" on Ethereum when it's part of a block that can't change.
-Because miners work in a decentralized way, two valid blocks can get mined at the same time. This creates a temporary fork. Eventually, one of these chains will become the accepted chain after a subsequent block has been mined and added, making it longer.
+Because miners worked in a decentralized way, two valid blocks could be mined at the same time. This creates a temporary fork. Eventually, one of these chains became the accepted chain after subsequent blocks were mined and added to it, making it longer.
-But to complicate things further, transactions rejected on the temporary fork may have been included in the accepted chain. This means it could get reversed. So finality refers to the time you should wait before considering a transaction irreversible. For Ethereum, the recommended time is six blocks or just over 1 minute. After six blocks, you can say with relative confidence that the transaction was successful. You can wait longer for even greater assurances.
-
-Finality is something to bear in mind when designing dapps. It would be a poor user experience to misrepresent transaction information to your users, especially if the transaction is of high value.
-
-Remember, this timing doesn't include the wait times for having a transaction picked up by a miner.
+To complicate things further, transactions rejected on the temporary fork may not have been included in the accepted chain. This means it could get reversed. So finality refers to the time you should wait before considering a transaction irreversible. Under the previous proof-of-work Ethereum, the more blocks were mined on top of a specific block `N`, the higher confidence that the transactions in `N` were successful and would not be reverted. Now, with proof-of-stake, finalization is an explicit, rather than probabilistic, property of a block.
## Proof-of-work energy-usage {#energy}
-A major criticism of proof-of-work is the amount of energy output required to keep the network safe. To maintain security and decentralization, Ethereum on proof-of-work consumes 73.2 TWh annually, the energy equivalent of a medium-sized country like Austria.
+A major criticism of proof-of-work is the amount of energy output required to keep the network safe. To maintain security and decentralization, Ethereum on proof-of-work consumed large amounts of energy. Shortly before switching to proof-of-stake, Ethereum miners were collectively consuming about 70 TWh/yr (about the same as the Czech Republic - according to [digiconomist](digiconomist.net) on 18-July-2022).
## Pros and cons {#pros-and-cons}
diff --git a/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash/index.md b/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash/index.md
index b937f7ea659..22a6ee8230f 100644
--- a/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash/index.md
+++ b/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash/index.md
@@ -5,9 +5,15 @@ lang: en
sidebar: true
---
-**Note that Ethash is Ethereum's proof-of-work mining algorithm. Proof-of-work mining will be switched off completely at [The Merge](/upgrades/merge) at which point Ethereum will be secured using a [proof-of-stake](/developers/docs/consensus-mechanisms/pos) mechanism instead.**
+
+ Ethash was Ethereum's proof-of-work mining algorithm. Proof-of-work has now been **switched off entirely** and Ethereum is now secured using [proof-of-stake](/developers/docs/consensus-mechanisms/pos) instead. Read more on The Merge, proof-of-stake and staking. This page is for historical interest!
+
-[Ethash](https://github.com/ethereum/wiki/wiki/Ethash) is a modified version of the [Dagger-Hashimoto](/developers/docs/consensus-mechanisms/pow/mining-algorithms/dagger-hashamoto) algorithm. Ethash proof-of-work is [memory hard](https://wikipedia.org/wiki/Memory-hard_function), which was thought to make the algorithm ASIC resistant, but ASIC Ethash-mining has since been shown to be possible. Memory hardness is achieved with a proof of work algorithm that requires choosing subsets of a fixed resource dependent on the nonce and block header. This resource (a few gigabytes in size) is called a DAG. The DAG is changed every 30000 blocks, a 125-hour window called an epoch (roughly 5.2 days) and takes a while to generate. Since the DAG only depends on block height, it can be pre-generated but if it's not, the client needs to wait until the end of this process to produce a block. If clients do not pre-generate and cache DAGs ahead of time the network may experience massive block delay on each epoch transition. Note that the DAG does not need to be generated for verifying the proof-of-work essentially allowing for verification with both low CPU and small memory.
+[Ethash](https://github.com/ethereum/wiki/wiki/Ethash) is a modified version of the [Dagger-Hashimoto](/developers/docs/consensus-mechanisms/pow/mining-algorithms/dagger-hashamoto) algorithm. Ethash proof-of-work is [memory hard](https://wikipedia.org/wiki/Memory-hard_function), which was thought to make the algorithm ASIC resistant. Ethash ASICs were eventually developed but GPU mining was still a viable option until proof-of-work was switched off. Ethash is still used to mine other coins on other non-Ethereum proof-of-work networks.
+
+## How does Ethash work? {#how-does-ethash-work}
+
+Memory hardness is achieved with a proof of work algorithm that requires choosing subsets of a fixed resource dependent on the nonce and block header. This resource (a few gigabytes in size) is called a DAG. The DAG is changed every 30000 blocks, a ~125-hour window called an epoch (roughly 5.2 days) and takes a while to generate. Since the DAG only depends on block height, it can be pre-generated, but if it's not the client needs to wait until the end of this process to produce a block. If clients do not pre-generate and cache DAGs ahead of time the network may experience massive block delay on each epoch transition. Note that the DAG does not need to be generated for verifying the proof-of-work essentially allowing for verification with both low CPU and small memory.
The general route that the algorithm takes is as follows:
diff --git a/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/index.md b/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/index.md
index dae534116c8..a14096d619d 100644
--- a/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/index.md
+++ b/src/content/developers/docs/consensus-mechanisms/pow/mining-algorithms/index.md
@@ -3,12 +3,16 @@ title: Mining algorithms
description: A detailed look at the algorithms used for Ethereum mining.
lang: en
sidebar: true
-preMergeBanner: true
---
-Ethereum mining has used two mining algorithms, Dagger Hashimoto and Ethash. Dagger Hashimoto was never used to mine Ethereum, being superseded by Ethash before mainet launched. It was a R&D mining algorithm that paved the way for Ethash. However, it has historical significance as an important innovation in Ethereum's development. Proof-of-work mining itself will be deprecated in favor of proof-of-stake during [The Merge](/upgrades/merge/), which is forecast to happen in Q3-Q4 2022.
+
-The fundamental idea of both mining algorithms is that a miner tries to find a nonce input using brute force computation so that the result is below a certain difficulty threshold. This difficulty threshold can be dynamically adjusted, allowing block production to happen at a regular interval.
+Proof-of-work is no longer underlying Ethereum's consensus mechanism, meaning mining has been switched off. Instead, Ethereum is secured by validators who stake ETH. You can start staking your ETH today. Read more on [The Merge](/upgrades/merge/), [proof-of-stake](/developers/docs/consensus-mechanisms/pos/), and [staking](/staking/). This page is for historical interest only.
+
+
+
+
+Ethereum mining used an algorithm known as Ethash. The fundamental idea of the algorithm is that a miner tries to find a nonce input using brute force computation so that the resulting hash is smaller than a threshold determined by the calculated difficulty. This difficulty level can be dynamically adjusted, allowing block production to happen at a regular interval.
## Prerequisites {#prerequisites}
@@ -16,7 +20,7 @@ To better understand this page, we recommend you first read up on [proof-of-work
## Dagger Hashimoto {#dagger-hashimoto}
-Dagger Hashimoto was a precursor research algorithm for Ethereum mining that Ethash superseded. It was an amalgamation of two different algorithms: Dagger and Hashimoto.
+Dagger Hashimoto was a precursor research algorithm for Ethereum mining that Ethash superseded. It was an amalgamation of two different algorithms: Dagger and Hashimoto. It was only ever a research implementation and was superceded by Ethash by the time Ethereum Mainnet launched.
[Dagger](http://www.hashcash.org/papers/dagger.html) involves the generation of a [Directed Acyclic Graph](https://en.wikipedia.org/wiki/Directed_acyclic_graph), random slices of which get hashed together. The core principle is that each nonce only requires a small portion of a large total data tree. Recomputing the subtree for each nonce is prohibitive for mining - hence the need to store the tree - but okay for a single nonce’s worth of verification. Dagger was designed to be an alternative to existing algorithms like Scrypt, which are memory-hard but difficult to verify when their memory-hardness increases to genuinely secure levels. However, Dagger was vulnerable to shared memory hardware acceleration and dropped in favor of other avenues of research.
@@ -28,7 +32,7 @@ More on [Dagger-Hashimoto](/developers/docs/consensus-mechanisms/pow/mining-algo
## Ethash {#ethash}
-Ethash is Ethereum's current mining algorithm. Ethash was effectively a new name given to a specific version of Dagger-Hashimoto after the algorithm got significantly updated, whilst still inheriting the fundamental principles of its predecessor. Ethereum mainnet has only ever used Ethash - Dagger Hashimoto was an R&D version of the mining algorithm that was superseded before mining started on Ethereum mainnet.
+Ethash was the mining algorithm that was actually used on the real Ethereum Mainnet under the now deprecated proof-of-work architecture. Ethash was effectively a new name given to a specific version of Dagger-Hashimoto after the algorithm got significantly updated, whilst still inheriting the fundamental principles of its predecessor. Ethereum Mainnet only ever used Ethash - Dagger Hashimoto was an R&D version of the mining algorithm that was superseded before mining started on Ethereum mainnet.
[More on Ethash](/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash).
diff --git a/src/content/developers/docs/consensus-mechanisms/pow/mining/index.md b/src/content/developers/docs/consensus-mechanisms/pow/mining/index.md
index 08c9078bc63..f71197a90b1 100644
--- a/src/content/developers/docs/consensus-mechanisms/pow/mining/index.md
+++ b/src/content/developers/docs/consensus-mechanisms/pow/mining/index.md
@@ -1,13 +1,12 @@
---
title: Mining
-description: An explanation of how mining works in Ethereum and how it helps keep Ethereum secure and decentralized.
+description: An explanation of how mining worked on Ethereum.
lang: en
sidebar: true
-preMergeBanner: true
---
- Proof-of-stake will soon replace proof-of-work as Ethereum's consensus mechanism, meaning mining will be switched off. Instead, Ethereum will be secured by validators who stake ETH. You can start staking your ETH today. Read more on The Merge, proof-of-stake and staking.
+ Proof-of-work is no longer underlying Ethereum's consensus mechanism, meaning mining has been switched off. Instead, Ethereum is secured by validators who stake ETH. You can start staking your ETH today. Read more on [The Merge](/upgrades/merge/), [proof-of-stake](/developers/docs/consensus-mechanisms/pos/), and [staking](/staking/). This page is for historical interest.
## Prerequisites {#prerequisites}
@@ -16,34 +15,32 @@ To better understand this page, we recommend you first read up on [transactions]
## What is Ethereum mining? {#what-is-ethereum-mining}
-Mining is the process of creating a block of transactions to be added to the Ethereum blockchain.
+Mining is the process of creating a block of transactions to be added to the Ethereum blockchain in Ethereum's now-deprecated proof-of-work architecture.
-The word mining originates in the context of the gold analogy for crypto currencies. Gold or precious metals are scarce, so are digital tokens, and the only way to increase the total volume is through mining. This is appropriate to the extent that in Ethereum too, the only mode of issuance post launch is via mining. Unlike these examples however, mining is also the way to secure the network by creating, verifying, publishing and propagating blocks in the blockchain.
+The word mining originates in the context of the gold analogy for cryptocurrencies. Gold or precious metals are scarce, so are digital tokens, and the only way to increase the total volume in a proof-of-work system is through mining. In proof-of-work Ethereum, the only mode of issuance was via mining. Unlike gold or precious metals however, Ethereum mining was also the way to secure the network by creating, verifying, publishing and propagating blocks in the blockchain.
Mining ether = Securing the Network
-Ethereum, like Bitcoin, currently uses a [proof-of-work (PoW)](/developers/docs/consensus-mechanisms/pow/) consensus mechanism. Mining is the lifeblood of proof-of-work. Ethereum miners - computers running software - using their time and computation power to process transactions and produce blocks.
+Mining is the lifeblood of any proof-of-work blockchain. Ethereum miners - computers running software - used their time and computation power to process transactions and produce blocks prior to the transition to proof-of-stake.
## Why do miners exist? {#why-do-miners-exist}
-In decentralized systems like Ethereum, we need to ensure that everyone agrees on the order of transactions. Miners help this happen by solving computationally difficult puzzles to produce blocks, securing the network from attacks.
+In decentralized systems like Ethereum, we need to ensure that everyone agrees on the order of transactions. Miners helped this happen by solving computationally difficult puzzles to produce blocks, securing the network from attacks.
[More on proof-of-work](/developers/docs/consensus-mechanisms/pow/)
-## Who can become a miner on Ethereum? {#who-can-become-a-miner}
-
-Technically, anyone can mine on the Ethereum network using their computer. However, not everyone can mine ether (ETH) profitably. In most cases, miners must purchase dedicated computer hardware to mine profitably. While it is true anyone can run the mining software on their computer, it is unlikely that the average computer would earn enough block rewards to cover the associated costs of mining.
+Anyone was previously able to mine on the Ethereum network using their computer. However, not everyone could mine ether (ETH) profitably. In most cases, miners had to purchase dedicated computer hardware, and have access to inexpensive energy sources. The average computer was unlikely to earn enough block rewards to cover the associated costs of mining.
### Cost of mining {#cost-of-mining}
- Potential costs of the hardware necessary to build and maintain a mining rig
- Electrical cost of powering the mining rig
-- If you are mining in a pool, mining pools typically charge a flat % fee of each block generated by the pool
+- If you were mining in a pool, these pools typically charged a flat % fee of each block generated by the pool
- Potential cost of equipment to support mining rig (ventilation, energy monitoring, electrical wiring, etc.)
To further explore mining profitability, use a mining calculator, such as the one [Etherscan](https://etherscan.io/ether-mining-calculator) provides.
-## How Ethereum transactions are mined {#how-ethereum-transactions-are-mined}
+## How Ethereum transactions were mined {#how-ethereum-transactions-were-mined}
1. A user writes and signs a [transaction](/developers/docs/transactions/) request with the private key of some [account](/developers/docs/accounts/).
2. The user broadcasts the transaction request to the entire Ethereum network from some [node](/developers/docs/nodes-and-clients/).
@@ -66,9 +63,9 @@ Watch Austin walk you through mining and the proof-of-work blockchain.
## The mining algorithm {#mining-algorithm}
-The Ethereum mining algorithm has undergone several upgrades since its inception. The original algorithm, "Dagger Hashimoto" was based around the provision of a large, transient, randomly generated dataset which forms a [Directed Acyclic Graph](https://en.wikipedia.org/wiki/Directed_acyclic_graph) (the Dagger-part), with miners attempting to solve a particular constraint on it, partly determined through a block’s header-hash. This algorithm was novel because it had high memory-access bandwidth requirements but could be run using a modest processor, making it GPU-friendly but resistant to the type of ASIC-driven hardware arms race that could pose a centralization risk (more on [problems with ASICS](https://www.investopedia.com/investing/why-centralized-crypto-mining-growing-problem/)). After substantial upgrades to the algorithm, it was renamed to "Ethash". This renaming happened before mining began on Ethereum mainnet. Dagger-Hashimoto was a precursor, research algorithm that was not used on Ethereum mainnet.
+Ethereum Mainnet only ever used one mining algorithm - ['Ethash'](/developers/docs/consensus-mechanisms/pow/mining/mining-algorithms/ethash). Ethhash was the successor to an original R&D algorithm known as ['Dagger-Hashamoto'](/developers/docs/consensus-mechanisms/pow/mining/mining-algorithms/dagger-hashamoto).
-More information on these mining algorithms is available at our [mining algorithms page](/developers/docs/consensus-mechanisms/pow/mining-algorithms/).
+[More on mining algorithms](/developers/docs/consensus-mechanisms/pow/mining-algorithms/).
## Further reading {#further-reading}
diff --git a/src/content/developers/docs/dapps/index.md b/src/content/developers/docs/dapps/index.md
index dbe336e3137..d33e5b29331 100644
--- a/src/content/developers/docs/dapps/index.md
+++ b/src/content/developers/docs/dapps/index.md
@@ -3,7 +3,6 @@ title: Introduction to dapps
description:
lang: en
sidebar: true
-preMergeBanner: true
---
A decentralized application (dapp) is an application built on a decentralized network that combines a [smart contract](/developers/docs/smart-contracts/) and a frontend user interface. On Ethereum, smart contracts are accessible and transparent – like open APIs – so your dapp can even include a smart contract that someone else has written.
@@ -40,7 +39,7 @@ A smart contract is code that lives on the Ethereum blockchain and runs exactly
## Drawbacks of dapp development {#drawbacks-of-dapp-development}
- **Maintenance** – Dapps can be harder to maintain because the code and data published to the blockchain are harder to modify. It’s hard for developers to make updates to their dapps (or the underlying data stored by a dapp) once they are deployed, even if bugs or security risks are identified in an old version.
-- **Performance overhead** – There is a huge performance overhead, and scaling is really hard. To achieve the level of security, integrity, transparency, and reliability that Ethereum aspires to, every node runs and stores every transaction. On top of this, proof-of-work takes time as well. A back-of-the-envelope calculation puts the overhead at something like 1,000,000x that of standard computation currently.
+- **Performance overhead** – There is a huge performance overhead, and scaling is really hard. To achieve the level of security, integrity, transparency, and reliability that Ethereum aspires to, every node runs and stores every transaction. On top of this, proof-of-stake consensus takes time as well.
- **Network congestion** – When one dapp uses too many computational resources, the entire network gets backed up. Currently, the network can only process about 10-15 transactions per second; if transactions are being sent in faster than this, the pool of unconfirmed transactions can quickly balloon.
- **User experience** – It may be harder to engineer user-friendly experiences because the average end-user might find it too difficult to set up a tool stack necessary to interact with the blockchain in a truly secure fashion.
- **Centralization** – User-friendly and developer-friendly solutions built on top of the base layer of Ethereum might end up looking like centralized services anyways. For example, such services may store keys or other sensitive information server-side, serve a frontend using a centralized server, or run important business logic on a centralized server before writing to the blockchain. Centralization eliminates many (if not all) of the advantages of blockchain over the traditional model.
diff --git a/src/content/developers/docs/data-and-analytics/block-explorers/index.md b/src/content/developers/docs/data-and-analytics/block-explorers/index.md
index 7286c9ef25e..70850a2d5d1 100644
--- a/src/content/developers/docs/data-and-analytics/block-explorers/index.md
+++ b/src/content/developers/docs/data-and-analytics/block-explorers/index.md
@@ -4,7 +4,6 @@ description: An introduction to block explorers, your portal into the world of b
lang: en
sidebar: true
sidebarDepth: 3
-preMergeBanner: true
---
Block explorers are your portal to Ethereum's data. You can use them to see real-time data on blocks, transactions, miners, accounts, and other on-chain activity.
@@ -15,67 +14,54 @@ You should understand the basic concepts of Ethereum so you can make sense of th
## Services {#services}
-- [Etherscan](https://etherscan.io/) –_Also available in Chinese, Korean, Russian, and Japanese_
+- [Etherscan](https://etherscan.io/) -_Also available in Chinese, Korean, Russian, and Japanese_
- [Etherchain](https://www.etherchain.org/)
-- [Ethplorer](https://ethplorer.io/) –_Also available in Chinese, Spanish, French, Turkish, Russian, Korean and Vietnamese_
-- [Blockchair](https://blockchair.com/ethereum) –_Also available in Spanish, French, Italian, Dutch, Portuguese, Russian, Chinese, and Farsi_
+- [Ethplorer](https://ethplorer.io/) -_Also available in Chinese, Spanish, French, Turkish, Russian, Korean and Vietnamese_
+- [Blockchair](https://blockchair.com/ethereum) -_Also available in Spanish, French, Italian, Dutch, Portuguese, Russian, Chinese, and Farsi_
- [Blockscout](https://blockscout.com/)
- [OKLink](https://www.oklink.com/eth)
- [Otterscan](https://otterscan.io/)
## Data {#data}
-Ethereum is transparent by design so everything is verifiable. Block explorers provide an interface for getting this information. And this is for both the main Ethereum network and the testnets, should you need that data.
+Ethereum is transparent by design so everything is verifiable. Block explorers provide an interface for getting this information. And this is for both the main Ethereum network and the testnets, should you need that data. Data is divided into execution data and consensus data. The execution data refers to the transactions that have been executed in a specific block. The consensus data refers to the blocks themselves and the validators who proposed them.
Here's a summary of the types of data you can get from a block explorer.
-### Blocks {#blocks}
+### Execution data {#execution-data}
-New blocks are added to Ethereum every ~12 seconds (this can fluctuate) so there's a near-constant stream of data that gets added to block explorers. Blocks contain a lot of important data that you may find useful:
+New blocks are added to Ethereum every 12 seconds (unless a block proposer misses its turn), so a near-constant stream of data gets added to block explorers. Blocks contain a lot of important data that you may find useful:
**Standard data**
-- Block height – The block number and length of the blockchain (in blocks) on creation of the current block.
-- Timestamp – The time at which a miner mined the block.
-- Transactions – The number of transactions included within the block.
-- Miner – The address of the miner who mined the block.
-- Reward – The amount of ETH awarded to the miner for adding the block (standard 2ETH reward + any transaction fees of transactions included in the block).
-- Difficulty – The difficulty associated with mining the block.
-- Size – The size of the data within the block (measured in bytes).
-- Gas used – The total units of gas used by the transactions in the block.
-- Gas limit – The total gas limits set by the transactions in the block.
-- Extra data – Any extra data the miner has included in the block.
+- Block height - The block number and length of the blockchain (in blocks) on creation of the current block
+- Timestamp - The time at which a block was proposed
+- Transactions - The number of transactions included within the block
+- Fee recipient - The address that received gas fee tips from transactions
+- Block Reward - The amount of ETH awarded to the validator who proposed the block
+- Size - The size of the data within the block (measured in bytes)
+- Gas used - The total units of gas used by the transactions in the block
+- Gas limit - The total gas limits set by the transactions in the block
+- Base fee per gas - The minimum multiplier required for a transaction to be included in a block
+- Burnt fees - How much ETH is burned in the block
+- Extra data - Any extra data the miner has included in the block
**Advanced data**
-- Hash – The cryptographic hash that represents the block header (the unique identifier of the block).
-- Parent hash – The hash of the block that came before the current block.
-- Sha3Uncles – The combined hash of all uncles for a given parent.
-- StateRoot – The root hash of Merkle trie which stores the entire state of the system.
-- Nonce – A value used to demonstrate proof-of-work for a block by the miner.
-
-**Uncle blocks**
-
-Uncle blocks are created when two miners create blocks at near-enough the same time – only one block can be validated across the nodes. They are not included but still receive a reward for the work.
-
-Block explorers provide information about uncle blocks like:
-
-- An uncle block number.
-- A time they occurred.
-- The block height at which they were created.
-- Who mined it.
-- The ETH reward.
+- Hash - The cryptographic hash that represents the block header (the unique identifier of the block)
+- Parent hash - The hash of the block that came before the current block
+- StateRoot - The root hash of Merkle trie which stores the entire state of the system
### Gas {#gas}
Not only will block explorers give you data about Gas usage in transactions and blocks, but some will give you information on the network's current gas prices. This will help you understand network usage, submit safe transactions and not overspend on gas. Look out for APIs that can help you get this information into your product's interface. Gas-specific data covers:
-- Estimated units of gas needed for a safe but slow transaction (+ estimated price and duration).
-- Estimated units of gas needed for an average transaction (+ estimated price and duration).
-- Estimated units of gas needed for a fast transaction (+ estimated price and duration).
-- Average confirmation time based on gas price.
-- Contracts that are consuming gas – in other words, popular products that are seeing lots of usage on the network.
-- Accounts that are spending gas – in other words, frequent network users.
+- Estimated units of gas needed for a safe but slow transaction (+ estimated price and duration)
+- Estimated units of gas needed for an average transaction (+ estimated price and duration)
+- Estimated units of gas needed for a fast transaction (+ estimated price and duration)
+- Average confirmation time based on gas price
+- Contracts that are consuming gas - in other words, popular products that are seeing lots of usage on the network
+- Accounts that are spending gas - in other words, frequent network users
### Transactions {#transactions}
@@ -83,23 +69,23 @@ Block explorers have become a common place for people to track the progress of t
**Standard data**
-- Transaction hash – A hash generated when the transaction is submitted.
-- Status – An indication of whether the transaction is pending, failed or a success.
-- Block – The block in which the transaction has been included.
-- Timestamp – The time at which a miner mined the transaction.
-- From – The address of the account that submitted the transaction.
-- To – The address of the recipient or smart contract that the transaction interacts with.
-- Tokens transferred – A list of tokens that were transferred as part of the transaction.
-- Value – The total ETH value being transferred.
-- Transaction fee – The amount paid to the miner to process the transaction (calculated by gas price\*gas used).
+- Transaction hash - A hash generated when the transaction is submitted
+- Status - An indication of whether the transaction is pending, failed or a success
+- Block - The block in which the transaction has been included
+- Timestamp - The time at which a miner mined the transaction
+- From - The address of the account that submitted the transaction
+- To - The address of the recipient or smart contract that the transaction interacts with
+- Tokens transferred - A list of tokens that were transferred as part of the transaction
+- Value - The total ETH value being transferred
+- Transaction fee - The amount paid to the miner to process the transaction (calculated by gas price\*gas used)
**Advanced data**
-- Gas limit – The maximum numbers of gas units this transaction can consume.
-- Gas used – The actual amount of gas units the transaction consumed.
-- Gas price – The price set per gas unit.
-- Nonce – The transaction number for the `from` address (bear in mind this starts at 0 so a nonce of `100` would actually be the 101st transaction submitted by this account.
-- Input data – Any extra information required by the transaction.
+- Gas limit - The maximum numbers of gas units this transaction can consume
+- Gas used - The actual amount of gas units the transaction consumed
+- Gas price - The price set per gas unit
+- Nonce - The transaction number for the `from` address (bear in mind this starts at 0 so a nonce of `100` would actually be the 101st transaction submitted by this account
+- Input data - Any extra information required by the transaction
### Accounts {#accounts}
@@ -107,163 +93,144 @@ There's a lot of data that you can access about an account. This is why it's oft
**User accounts**
-- Account address – The public address you can use to send funds to.
-- ETH balance – The amount of ETH associated with that account.
-- Total ETH value – The value of the ETH.
-- Tokens – The tokens associated with the account and their value.
-- Transaction history – A list of all the transactions where this account was either the sender or the recipient.
+- Account address - The public address you can use to send funds to
+- ETH balance - The amount of ETH associated with that account
+- Total ETH value - The value of the ETH
+- Tokens - The tokens associated with the account and their value
+- Transaction history - A list of all the transactions where this account was either the sender or the recipient
**Smart contracts**
Smart contract accounts have all the data that a user account will have, but some block explorers will even display some code information too. Examples include:
-- Contract creator – The address that deployed the contract to Mainnet.
-- Creation transaction – The transaction that included the deployment to Mainnet.
-- Source code – The solidity or vyper code of the smart contract.
-- Contract ABI – The Application Binary Interface of the contract – the calls the contract makes and the data received.
-- Contract creation code – The compiled bytecode of the smart contract – created when you compile a smart contract written in Solidity or Vyper, etc.
-- Contract events – A history of the methods called in the smart contract. Basically a way to see how the contract is being used and how often.
+- Contract creator - The address that deployed the contract to Mainnet
+- Creation transaction - The transaction that included the deployment to Mainnet
+- Source code - The solidity or vyper code of the smart contract
+- Contract ABI - The Application Binary Interface of the contract—the calls the contract makes and the data received
+- Contract creation code - The compiled bytecode of the smart contract—created when you compile a smart contract written in Solidity or Vyper, etc.
+- Contract events - A history of the methods called in the smart contract—basically a way to see how the contract is being used and how often
### Tokens {#tokens}
Tokens are a type of contract so they'll have similar data to a smart contract. But because they have value and can be traded they have additional data points:
-- Type – Whether they're an ERC-20, ERC-721 or another token standard.
-- Price – If they're an ERC-20 they'll have a current market value.
-- Market cap – If they're an ERC-20 they'll have a market cap (calculated by price\*total supply).
-- Total supply – The number of tokens in circulation.
-- Holders – The number of addresses that hold the token.
-- Transfers – The number of times the token has been transferred between accounts.
-- Transaction history – A history of all the transactions including the token.
-- Contract address – The address of the token that was deployed to Mainnet.
-- Decimals – ERC-20 tokens are divisible and have decimal places.
+- Type - Whether they're an ERC-20, ERC-721 or another token standard
+- Price - If they're an ERC-20 they'll have a current market value
+- Market cap - If they're an ERC-20 they'll have a market cap (calculated by price\*total supply)
+- Total supply - The number of tokens in circulation
+- Holders - The number of addresses that hold the token
+- Transfers - The number of times the token has been transferred between accounts
+- Transaction history - A history of all the transactions including the token
+- Contract address - The address of the token that was deployed to Mainnet
+- Decimals - ERC-20 tokens are divisible and have decimal places
### Network {#network}
-Of course there's some data that speaks to the health of the network. These are quite specific to Ethereum's proof-of-work consensus mechanism. When Ethereum transitions to proof-of-stake some of this data will be redundant
+Some block data is concerned about the health of Ethereum more holistically.
-- Difficulty – The current mining difficulty.
-- Hashrate – An estimate of how many hashes are being generated by Ethereum miners trying to solve the current Ethereum block or any given block.
-- Total transactions – The number of transactions since Ethereum was created.
-- Transactions per second – The number of transactions processable within a second.
-- ETH price – The current valuations of 1 ETH.
-- Total ETH supply – Number of ETH in circulation – remember new ETH is created with the creation of every block in the form of block rewards.
-- Market cap – Calculation of price\*supply.
+- Total transactions - The number of transactions since Ethereum was created
+- Transactions per second - The number of transactions processable within a second
+- ETH price - The current valuations of 1 ETH
+- Total ETH supply - Number of ETH in circulation—remember new ETH is created with the creation of every block in the form of block rewards
+- Market cap - Calculation of price\*supply
## Consensus layer data {#consensus-layer-data}
-The scalability upgrades are still in development but it's worth talking about some of the data points that explorers will be able to provide you. In fact, all of this data is available right now for the testnets.
-
-If you're not familiar with the road map, check out [our overview of the Ethereum upgrades](/upgrades/).
-
### Epoch {#epoch}
-The Beacon Chain will create committees of validators which are randomized at the end of every epoch (every 6.4 minutes) for security reasons. Epoch data includes:
+For security reasons, randomized committees of validators are created at the end of every epoch (every 6.4 minutes). Epoch data includes:
-- Epoch number.
-- Finalized status – Whether the epoch has been finalized (Yes/No).
-- Time – The time the epoch ended.
-- Attestations – The number of attestations in the epoch (votes for blocks within slots).
-- Deposits – The number of ETH deposits included in the epoch (validators must stake ETH to become validators).
-- Slashings – Number of penalties given to proposers of blocks or attestors.
-- Voting participation – The amount of staked ETH used to attest blocks.
-- Validators – Number of validators active for the epoch.
-- Average Validator balance – Average balance for active validators.
-- Slots – Number of slots included in the epoch (slots include one valid block).
+- Epoch number
+- Finalized status - Whether the epoch has been finalized (Yes/No)
+- Time - The time the epoch ended
+- Attestations - The number of attestations in the epoch (votes for blocks within slots)
+- Deposits - The number of ETH deposits included in the epoch (validators must stake ETH to become validators)
+- Slashings - Number of penalties given to proposers of blocks or attestors
+- Voting participation - The amount of staked ETH used to attest blocks
+- Validators - Number of validators active for the epoch
+- Average Validator balance - Average balance for active validators
+- Slots - Number of slots included in the epoch (slots include one valid block)
### Slot {#slot}
Slots are opportunities for block creation, the data available for each slot includes:
-- Epoch – The epoch in which the slot is valid.
-- Slot number.
-- Status – The status of the slot (Proposed/Missed).
-- Time – The slot timestamp.
-- Proposer – The validator that proposed the block for the slot.
-- Block root – The hash-tree-root of the BeaconBlock.
-- Parent root – The hash of the block that came before.
-- State root – The hash-tree-root of the BeaconState.
-- Signature.
-- Randao reveal.
-- Graffiti – A block proposer can include 32 byte long message to its block proposal.
-- Execution Data.
- - Block hash.
- - Deposit count.
- - Deposit root.
-- Attestations – Number of attestations for the block in this slot.
-- Deposits – The number of deposits during this slot.
-- Voluntary exits – The number of validators that left during the slot.
-- Slashings – Number of penalties given to proposers of blocks or attestors.
-- Votes – The validators that voted for the block in this slot.
+- Epoch - The epoch in which the slot is valid
+- Slot number
+- Status - The status of the slot (Proposed/Missed)
+- Time - The slot timestamp
+- Proposer - The validator that proposed the block for the slot
+- Block root - The hash-tree-root of the BeaconBlock
+- Parent root - The hash of the block that came before
+- State root - The hash-tree-root of the BeaconState
+- Signature
+- Randao reveal
+- Graffiti - A block proposer can include 32 byte long message to its block proposal
+- Execution Data
+ - Block hash
+ - Deposit count
+ - Deposit root
+- Attestations - Number of attestations for the block in this slot
+- Deposits - The number of deposits during this slot
+- Voluntary exits - The number of validators that left during the slot
+- Slashings - Number of penalties given to proposers of blocks or attestors
+- Votes - The validators that voted for the block in this slot
### Blocks {#blocks-1}
-Consensus layer blocks work differently because miners are replaced by validators and the Beacon Chain introduces slots and epochs to Ethereum. So that means new data!
+Proof-of-stake divides time into slots and epochs. So that means new data!
-- Proposer – The validator that was algorithmically chosen to propose the new block.
-- Epoch – The epoch in which the block was proposed.
-- Slot – The slot in which the block was proposed.
-- Attestations – The number of attestation included in the slot. Attestations are like votes that indicate the block is ready to go to the Beacon Chain.
+- Proposer - The validator that was algorithmically chosen to propose the new block
+- Epoch - The epoch in which the block was proposed
+- Slot - The slot in which the block was proposed
+- Attestations - The number of attestation included in the slot—attestations are like votes that indicate the block is ready to go to the Beacon Chain
### Validators {#validators}
Validators are responsible for proposing blocks and attesting to them within slots.
-- Validator number – Unique number that represents the validator.
-- Current balance – The validator's balance including rewards.
-- Effective balance – The validator's balance that is used for staking.
-- Income – The rewards or penalties received by the validator.
-- Status – Whether the validator is currently online and active or not.
-- Attestation effectiveness – The average time it takes for the validator's attestations to be included in the chain.
-- Eligibility for activation – Date (and epoch) when the validator became available to validate.
-- Active since – Date (and epoch) when the validator became active.
-- Proposed blocks – The block that the validator has proposed.
-- Attestations – The attestations that the validator has provided.
-- Deposits – The from address, transaction hash, block number, timestamp, amount and status of the staking deposit made by the validator.
+- Validator number - Unique number that represents the validator
+- Current balance - The validator's balance including rewards
+- Effective balance - The validator's balance that is used for staking
+- Income - The rewards or penalties received by the validator
+- Status - Whether the validator is currently online and active or not
+- Attestation effectiveness - The average time it takes for the validator's attestations to be included in the chain
+- Eligibility for activation - Date (and epoch) when the validator became available to validate
+- Active since - Date (and epoch) when the validator became active
+- Proposed blocks - The block that the validator has proposed
+- Attestations - The attestations that the validator has provided
+- Deposits - The from address, transaction hash, block number, timestamp, amount and status of the staking deposit made by the validator
### Attestations {#attestations}
Attestations are "yes" votes to include blocks in the chain. Their data relates to a record of the attestation and the validators who attested
-- Slot – The slot in which the attestation took place.
-- Committee index – The index of the committee at the given slot.
-- Aggregation bits – Represents the aggregated attestation of all participating validators in the attestation.
-- Validators – The validators that provided attestations.
-- Beacon block root – Points to the block to which validators are attesting.
-- Source – Points to the latest justified epoch.
-- Target – Points to the latest epoch boundary.
-- Signature.
+- Slot - The slot in which the attestation took place
+- Committee index - The index of the committee at the given slot
+- Aggregation bits - Represents the aggregated attestation of all participating validators in the attestation
+- Validators - The validators that provided attestations
+- Beacon block root - Points to the block to which validators are attesting
+- Source - Points to the latest justified epoch
+- Target - Points to the latest epoch boundary
+- Signature
### Network {#network-1}
The consensus layer top-level data includes the following:
-- Current epoch.
-- Current slot.
-- Active validators – Number of active validators.
-- Pending validators – Number of validators waiting for to be made active.
-- Staked ETH – Amount of ETH staked in the network.
-- Average balance – Average ETH balance of validators.
+- Current epoch
+- Current slot
+- Active validators - Number of active validators
+- Pending validators - Number of validators waiting for to be made active
+- Staked ETH - Amount of ETH staked in the network
+- Average balance - Average ETH balance of validators
## Block explorers {#block-explorers}
-- [Etherscan](https://etherscan.io/) – a block explorer you can use to fetch data for Ethereum Mainnet, Ropsten Testnet, Kovan Testnet, Rinkeby Testnet, and Goerli Testnet.
-- [Blockscout](https://blockscout.com/) – focuses on the following networks:
- - xDai – a clever combination of MakerDAO's DAI stablecoin and POA's sidechain and tokenbridge technology.
- - POA – A sidechain and autonomous network secured by a group of trusted validators. All validators on the network are United States notaries, and their information is publicly available.
- - POA Sokol Testnet.
- - ARTIS – an Ethereum compliant blockchain.
- - [LUKSO L14](https://blockscout.com/lukso/l14) – L14 functions as the first test-network, to allow the LUKSO community to build and test on a common infrastructure.
- - qDai.
-- [Etherchain](https://www.etherchain.org/) – a block explorer for the Ethereum Mainnet.
-- [Ethplorer](https://ethplorer.io/) – a block explorer with a focus on tokens for the Ethereum Mainnet and the Kovan testnet.
-- [Blockchair](https://blockchair.com/ethereum) - the most private Ethereum explorer. Also for sorting and filtering (mempool) data.
-
-## Beacon chain (consensus layer) block explorers {#beacon-chain-block-explorers}
-
-- [https://beaconcha.in/](https://beaconcha.in/)
-- [https://beaconscan.com/](https://beaconscan.com/)
-- [https://ethscan.org/](https://ethscan.org/) (fork of beaconcha.in)
+- [Etherscan](https://etherscan.io/) - a block explorer you can use to fetch data for Ethereum Mainnet, Ropsten Testnet, Kovan Testnet, Rinkeby Testnet, and Goerli Testnet
+- [Etherchain](https://www.etherchain.org/) - a block explorer for the Ethereum Mainnet
+- [Ethplorer](https://ethplorer.io/) - a block explorer with a focus on tokens for the Ethereum Mainnet and the Kovan testnet
+- [Blockchair](https://blockchair.com/ethereum) - the most private Ethereum explorer. Also for sorting and filtering (mempool) data
## Further reading {#further-reading}
@@ -271,7 +238,6 @@ _Know of a community resource that helped you? Edit this page and add it!_
## Related topics {#related-topics}
-- [Mining](/developers/docs/consensus-mechanisms/pow/mining/)
- [Transactions](/developers/docs/transactions/)
- [Accounts](/developers/docs/accounts/)
- [Networks](/developers/docs/networks/)
diff --git a/src/content/developers/docs/data-and-analytics/index.md b/src/content/developers/docs/data-and-analytics/index.md
index 71f12212431..83dd3089510 100644
--- a/src/content/developers/docs/data-and-analytics/index.md
+++ b/src/content/developers/docs/data-and-analytics/index.md
@@ -21,7 +21,7 @@ In terms of architectural fundamentals, understanding what an [API](https://www.
Many [Block Explorers](/developers/docs/data-and-analytics/block-explorers/) offer [RESTful](https://www.wikipedia.org/wiki/Representational_state_transfer) [API](https://www.wikipedia.org/wiki/API) gateways that will provide developers visibility into real-time data on blocks, transactions, miners, accounts, and other on-chain activity.
-Developers can then process and transform this data to give their users unique insights and interactions with the [blockchain](/glossary/#blockchain).
+Developers can then process and transform this data to give their users unique insights and interactions with the [blockchain](/glossary/#blockchain). For example, [Etherscan](etherscan.io) provides execution and consensus data for every 12s slot.
## The Graph {#the-graph}
@@ -29,6 +29,10 @@ The [Graph Network](https://thegraph.com/) is a decentralized indexing protocol
Using [GraphQL](https://graphql.org/), developers can query any of the curated open APIs, known as sub-graphs, to acquire the necessary information they need to drive their dapp. By querying these indexed sub-graphs, Reports and dapps not only get performance and scalability benefits but also the built in accuracy provided by network consensus. As new improvements and/or sub-graphs are added to the network, your projects can rapidly iterate to take advantage of these enhancements.
+## Client diversity
+
+[Client diversity](/developers/docs/nodes-and-clients/client-diversity/) is important for the overall health of the Ethereum network because it provides resilience to bugs and exploits. There are now several client diversity dashboards including [clientdiversity.org](https://clientdiversity.org/), [rated.network](rated.network), [pool.invis.cloud](pool.invis.cloud), [slashed.info](slahed.info) and [Ethernodes](https://ethernodes.org/).
+
## Dune Analytics {#dune-analytics}
[Dune Analytics](https://dune.com/) pre-processes blockchain data into relational database (PostgreSQL and DatabricksSQL) tables, allows users to query blockchain data using SQL and build dashboards based on query results. On-chain data are organized into 4 raw tables: `blocks`, `transactions`, (event) `logs` and (call) `traces`. Popular contracts and protocols have been decoded, and each has its own set of event and call tables. Those event and call tables are processed further and organized into abstraction tables by the type of protocols, for example, dex, lending, stablecoins, etc.
@@ -38,4 +42,5 @@ Using [GraphQL](https://graphql.org/), developers can query any of the curated o
- [Graph Network Overview](https://thegraph.com/docs/en/about/network/)
- [Graph Query Playground](https://thegraph.com/explorer/subgraph/graphprotocol/graph-network-mainnet?version=current)
- [API code examples on EtherScan](https://etherscan.io/apis#contracts)
+- [Beaconcha.in Beacon Chain explorer](https://beaconcha.in)
- [Dune Basics](https://docs.dune.com/#dune-basics)
diff --git a/src/content/developers/docs/development-networks/index.md b/src/content/developers/docs/development-networks/index.md
index e42ad79d0ce..8cac676a572 100644
--- a/src/content/developers/docs/development-networks/index.md
+++ b/src/content/developers/docs/development-networks/index.md
@@ -3,7 +3,6 @@ title: Development Networks
description: An overview of development networks and the tools available to help build Ethereum applications.
lang: en
sidebar: true
-preMergeBanner: true
---
When building an Ethereum application with smart contracts, you'll want to run it on a local network to see how it works before deploying it.
@@ -20,7 +19,7 @@ Development networks are essentially Ethereum clients (implementations of Ethere
**Why not just run a standard Ethereum node locally?**
-You _could_ [run a node](/developers/docs/nodes-and-clients/#running-your-own-node) (like Geth, Erigon, or Nethermind) but since development networks are purpose-built for development, they often come packed with convenient features like:
+You _could_ [run a node](/developers/docs/nodes-and-clients/#running-your-own-node) but since development networks are purpose-built for development, they often come packed with convenient features like:
- Deterministically seeding your local blockchain with data (e.g. accounts with ETH balances)
- Instantly mining blocks with each transaction it receives, in order and with no delay
@@ -57,9 +56,9 @@ Some consensus clients have built-in tools for spinning up local Beacon chains f
- [Local testnet using Lighthouse](https://lighthouse-book.sigmaprime.io/setup.html#local-testnets)
- [Local testnet using Nimbus](https://github.com/status-im/nimbus-eth1/blob/master/fluffy/docs/local_testnet.md)
-### Public Beacon Test-chains {#public-beacon-testchains}
+### Public Ethereum Test-chains {#public-beacon-testchains}
-There are also public test implementations of the Beacon Chain. The recommended testnet with long-term support is Goerli (which will merge with the Prater chain in August 2022). The Ropsten Chain was recently merged with its own Beacon Chain and is currently still available for testing consensus client implementations and post-merge application development.
+There are also three current public test implementations of Ethereum. The recommended testnet with long-term support is Goerli. Sepolia is also expected to be maintained for the foreseeable future, but the validator set is permissioned meaning there is no general access to new validators on this testnet. The Ropsten chain is expected to be deprecated.
- [Goerli Staking Launchpad](https://goerli.launchpad.ethereum.org/)
- [Ropsten Staking Launchpad](https://ropsten.launchpad.ethereum.org/)
diff --git a/src/content/developers/docs/evm/index.md b/src/content/developers/docs/evm/index.md
index e538985bbaf..c852b1f387b 100644
--- a/src/content/developers/docs/evm/index.md
+++ b/src/content/developers/docs/evm/index.md
@@ -11,7 +11,7 @@ The Ethereum protocol itself exists solely for the purpose of keeping the contin
## Prerequisites {#prerequisites}
-Some basic familiarity with common terminology in computer science such as [bytes](https://wikipedia.org/wiki/Byte), [memory](https://wikipedia.org/wiki/Computer_memory), and a [stack]() are necessary to understand the EVM. It would also be helpful to be comfortable with cryptography/blockchain concepts like [hash functions](https://wikipedia.org/wiki/Cryptographic_hash_function), [proof-of-work](https://wikipedia.org/wiki/Proof_of_work) and the [Merkle tree](https://wikipedia.org/wiki/Merkle_tree).
+Some basic familiarity with common terminology in computer science such as [bytes](https://wikipedia.org/wiki/Byte), [memory](https://wikipedia.org/wiki/Computer_memory), and a [stack]() are necessary to understand the EVM. It would also be helpful to be comfortable with cryptography/blockchain concepts like [hash functions](https://wikipedia.org/wiki/Cryptographic_hash_function) and the [Merkle tree](https://wikipedia.org/wiki/Merkle_tree).
## From ledger to state machine {#from-ledger-to-state-machine}
diff --git a/src/content/developers/docs/evm/opcodes/index.md b/src/content/developers/docs/evm/opcodes/index.md
index 730c97d5b3c..deba31cbb38 100644
--- a/src/content/developers/docs/evm/opcodes/index.md
+++ b/src/content/developers/docs/evm/opcodes/index.md
@@ -16,158 +16,156 @@ Looking for an interactive reference? Check out [evm.codes](https://www.evm.code
For operations with dynamic gas costs, see [gas.md](https://github.com/wolflo/evm-opcodes/blob/main/gas.md).
-## Opcodes {#opcodes}
-
-| Stack | Name | Gas | Initial Stack | Resulting Stack | Mem / Storage | Notes |
-| :---: | :------------- | :---------------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------------- | :----------------------------- | :---------------------------------------------------------------------------- | :---------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------- |
-| 00 | STOP | 0 | | | | halt execution |
-| 01 | ADD | 3 | `a, b` | `a + b` | | (u)int256 addition modulo 2\*\*256 |
-| 02 | MUL | 5 | `a, b` | `a * b` | | (u)int256 multiplication modulo 2\*\*256 |
-| 03 | SUB | 3 | `a, b` | `a - b` | | (u)int256 addition modulo 2\*\*256 |
-| 04 | DIV | 5 | `a, b` | `a // b` | | uint256 division |
-| 05 | SDIV | 5 | `a, b` | `a // b` | | int256 division |
-| 06 | MOD | 5 | `a, b` | `a % b` | | uint256 modulus |
-| 07 | SMOD | 5 | `a, b` | `a % b` | | int256 modulus |
-| 08 | ADDMOD | 8 | `a, b, N` | `(a + b) % N` | | (u)int256 addition modulo N |
-| 09 | MULMOD | 8 | `a, b, N` | `(a * b) % N` | | (u)int256 multiplication modulo N |
-| 0A | EXP | [A1](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a1-exp) | `a, b` | `a ** b` | | uint256 exponentiation modulo 2\*\*256 |
-| 0B | SIGNEXTEND | 5 | `b, x` | `SIGNEXTEND(x, b)` | | [sign extend](https://wikipedia.org/wiki/Sign_extension) `x` from `(b+1)` bytes to 32 bytes |
+| Stack | Name | Gas | Initial Stack | Resulting Stack | Mem / Storage | Notes |
+| :---: | :------------- | :---------------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------------- | :------------------------------ | :---------------------------------------------------------------------------- | :---------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------- |
+| 00 | STOP | 0 | | | | halt execution |
+| 01 | ADD | 3 | `a, b` | `a + b` | | (u)int256 addition modulo 2\*\*256 |
+| 02 | MUL | 5 | `a, b` | `a * b` | | (u)int256 multiplication modulo 2\*\*256 |
+| 03 | SUB | 3 | `a, b` | `a - b` | | (u)int256 addition modulo 2\*\*256 |
+| 04 | DIV | 5 | `a, b` | `a // b` | | uint256 division |
+| 05 | SDIV | 5 | `a, b` | `a // b` | | int256 division |
+| 06 | MOD | 5 | `a, b` | `a % b` | | uint256 modulus |
+| 07 | SMOD | 5 | `a, b` | `a % b` | | int256 modulus |
+| 08 | ADDMOD | 8 | `a, b, N` | `(a + b) % N` | | (u)int256 addition modulo N |
+| 09 | MULMOD | 8 | `a, b, N` | `(a * b) % N` | | (u)int256 multiplication modulo N |
+| 0A | EXP | [A1](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a1-exp) | `a, b` | `a ** b` | | uint256 exponentiation modulo 2\*\*256 |
+| 0B | SIGNEXTEND | 5 | `b, x` | `SIGNEXTEND(x, b)` | | [sign extend](https://wikipedia.org/wiki/Sign_extension) `x` from `(b+1)` bytes to 32 bytes |
| 0C-0F | _invalid_ |
-| 10 | LT | 3 | `a, b` | `a < b` | | uint256 less-than |
-| 11 | GT | 3 | `a, b` | `a > b` | | uint256 greater-than |
-| 12 | SLT | 3 | `a, b` | `a < b` | | int256 less-than |
-| 13 | SGT | 3 | `a, b` | `a > b` | | int256 greater-than |
-| 14 | EQ | 3 | `a, b` | `a == b` | | (u)int256 equality |
-| 15 | ISZERO | 3 | `a` | `a == 0` | | (u)int256 iszero |
-| 16 | AND | 3 | `a, b` | `a && b` | | bitwise AND |
-| 17 | OR | 3 | `a, b` | `a \|\| b` | | bitwise OR |
-| 18 | XOR | 3 | `a, b` | `a ^ b` | | bitwise XOR |
-| 19 | NOT | 3 | `a` | `~a` | | bitwise NOT |
-| 1A | BYTE | 3 | `i, x` | `(x >> (248 - i * 8)) && 0xFF` | | `i`th byte of (u)int256 `x`, from the left |
-| 1B | SHL | 3 | `shift, val` | `val << shift` | | shift left |
-| 1C | SHR | 3 | `shift, val` | `val >> shift` | | logical shift right |
-| 1D | SAR | 3 | `shift, val` | `val >> shift` | | arithmetic shift right |
+| 10 | LT | 3 | `a, b` | `a < b` | | uint256 less-than |
+| 11 | GT | 3 | `a, b` | `a > b` | | uint256 greater-than |
+| 12 | SLT | 3 | `a, b` | `a < b` | | int256 less-than |
+| 13 | SGT | 3 | `a, b` | `a > b` | | int256 greater-than |
+| 14 | EQ | 3 | `a, b` | `a == b` | | (u)int256 equality |
+| 15 | ISZERO | 3 | `a` | `a == 0` | | (u)int256 iszero |
+| 16 | AND | 3 | `a, b` | `a && b` | | bitwise AND |
+| 17 | OR | 3 | `a, b` | `a \|\| b` | | bitwise OR |
+| 18 | XOR | 3 | `a, b` | `a ^ b` | | bitwise XOR |
+| 19 | NOT | 3 | `a` | `~a` | | bitwise NOT |
+| 1A | BYTE | 3 | `i, x` | `(x >> (248 - i * 8)) && 0xFF` | | `i`th byte of (u)int256 `x`, from the left |
+| 1B | SHL | 3 | `shift, val` | `val << shift` | | shift left |
+| 1C | SHR | 3 | `shift, val` | `val >> shift` | | logical shift right |
+| 1D | SAR | 3 | `shift, val` | `val >> shift` | | arithmetic shift right |
| 1E-1F | _invalid_ |
-| 20 | SHA3 | [A2](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a2-sha3) | `ost, len` | `keccak256(mem[ost:ost+len-1])` | | keccak256 |
+| 20 | SHA3 | [A2](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a2-sha3) | `ost, len` | `keccak256(mem[ost:ost+len-1])` | | keccak256 |
| 21-2F | _invalid_ |
-| 30 | ADDRESS | 2 | `.` | `address(this)` | | address of executing contract |
-| 31 | BALANCE | [A5](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a5-balance-extcodesize-extcodehash) | `addr` | `addr.balance` | | balance, in wei |
-| 32 | ORIGIN | 2 | `.` | `tx.origin` | | address that originated the tx |
-| 33 | CALLER | 2 | `.` | `msg.sender` | | address of msg sender |
-| 34 | CALLVALUE | 2 | `.` | `msg.value` | | msg value, in wei |
-| 35 | CALLDATALOAD | 3 | `idx` | `msg.data[idx:idx+32]` | | read word from msg data at index `idx` |
-| 36 | CALLDATASIZE | 2 | `.` | `len(msg.data)` | | length of msg data, in bytes |
-| 37 | CALLDATACOPY | [A3](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a3-copy-operations) | `dstOst, ost, len` | `.` | mem[dstOst:dstOst+len-1] := msg.data[ost:ost+len-1] | copy msg data |
-| 38 | CODESIZE | 2 | `.` | `len(this.code)` | | length of executing contract's code, in bytes |
-| 39 | CODECOPY | [A3](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a3-copy-operations) | `dstOst, ost, len` | `.` | | mem[dstOst:dstOst+len-1] := this.code[ost:ost+len-1] | copy executing contract's bytecode |
-| 3A | GASPRICE | 2 | `.` | `tx.gasprice` | | gas price of tx, in wei per unit gas [\*\*](https://github.com/ethereum/EIPs/blob/0341984ff14c8ce398f6d2b3e009c07cd99df8eb/EIPS/eip-1559.md#gasprice) |
-| 3B | EXTCODESIZE | [A5](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a5-balance-extcodesize-extcodehash) | `addr` | `len(addr.code)` | | size of code at addr, in bytes |
-| 3C | EXTCODECOPY | [A4](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a4-extcodecopy) | `addr, dstOst, ost, len` | `.` | mem[dstOst:dstOst+len-1] := addr.code[ost:ost+len-1] | copy code from `addr` |
-| 3D | RETURNDATASIZE | 2 | `.` | `size` | | size of returned data from last external call, in bytes |
-| 3E | RETURNDATACOPY | [A3](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a3-copy-operations) | `dstOst, ost, len` | `.` | mem[dstOst:dstOst+len-1] := returndata[ost:ost+len-1] | copy returned data from last external call |
-| 3F | EXTCODEHASH | [A5](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a5-balance-extcodesize-extcodehash) | `addr` | `hash` | | hash = addr.exists ? keccak256(addr.code) : 0 |
-| 40 | BLOCKHASH | 20 | `blockNum` | `blockHash(blockNum)` | |
-| 41 | COINBASE | 2 | `.` | `block.coinbase` | | address of miner of current block |
-| 42 | TIMESTAMP | 2 | `.` | `block.timestamp` | | timestamp of current block |
-| 43 | NUMBER | 2 | `.` | `block.number` | | number of current block |
-| 44 | DIFFICULTY | 2 | `.` | `block.difficulty` | | difficulty of current block |
-| 45 | GASLIMIT | 2 | `.` | `block.gaslimit` | | gas limit of current block |
-| 46 | CHAINID | 2 | `.` | `chain_id` | | push current [chain id](https://eips.ethereum.org/EIPS/eip-155) onto stack |
-| 47 | SELFBALANCE | 5 | `.` | `address(this).balance` | | balance of executing contract, in wei |
-| 48 | BASEFEE | 2 | `.` | `block.basefee` | | base fee of current block |
+| 30 | ADDRESS | 2 | `.` | `address(this)` | | address of executing contract |
+| 31 | BALANCE | [A5](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a5-balance-extcodesize-extcodehash) | `addr` | `addr.balance` | | balance, in wei |
+| 32 | ORIGIN | 2 | `.` | `tx.origin` | | address that originated the tx |
+| 33 | CALLER | 2 | `.` | `msg.sender` | | address of msg sender |
+| 34 | CALLVALUE | 2 | `.` | `msg.value` | | msg value, in wei |
+| 35 | CALLDATALOAD | 3 | `idx` | `msg.data[idx:idx+32]` | | read word from msg data at index `idx` |
+| 36 | CALLDATASIZE | 2 | `.` | `len(msg.data)` | | length of msg data, in bytes |
+| 37 | CALLDATACOPY | [A3](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a3-copy-operations) | `dstOst, ost, len` | `.` | mem[dstOst:dstOst+len-1] := msg.data[ost:ost+len-1] | copy msg data |
+| 38 | CODESIZE | 2 | `.` | `len(this.code)` | | length of executing contract's code, in bytes |
+| 39 | CODECOPY | [A3](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a3-copy-operations) | `dstOst, ost, len` | `.` | | mem[dstOst:dstOst+len-1] := this.code[ost:ost+len-1] | copy executing contract's bytecode |
+| 3A | GASPRICE | 2 | `.` | `tx.gasprice` | | gas price of tx, in wei per unit gas [\*\*](https://github.com/ethereum/EIPs/blob/0341984ff14c8ce398f6d2b3e009c07cd99df8eb/EIPS/eip-1559.md#gasprice) |
+| 3B | EXTCODESIZE | [A5](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a5-balance-extcodesize-extcodehash) | `addr` | `len(addr.code)` | | size of code at addr, in bytes |
+| 3C | EXTCODECOPY | [A4](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a4-extcodecopy) | `addr, dstOst, ost, len` | `.` | mem[dstOst:dstOst+len-1] := addr.code[ost:ost+len-1] | copy code from `addr` |
+| 3D | RETURNDATASIZE | 2 | `.` | `size` | | size of returned data from last external call, in bytes |
+| 3E | RETURNDATACOPY | [A3](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a3-copy-operations) | `dstOst, ost, len` | `.` | mem[dstOst:dstOst+len-1] := returndata[ost:ost+len-1] | copy returned data from last external call |
+| 3F | EXTCODEHASH | [A5](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a5-balance-extcodesize-extcodehash) | `addr` | `hash` | | hash = addr.exists ? keccak256(addr.code) : 0 |
+| 40 | BLOCKHASH | 20 | `blockNum` | `blockHash(blockNum)` | |
+| 41 | COINBASE | 2 | `.` | `block.coinbase` | | address of miner of current block |
+| 42 | TIMESTAMP | 2 | `.` | `block.timestamp` | | timestamp of current block |
+| 43 | NUMBER | 2 | `.` | `block.number` | | number of current block |
+| 44 | DIFFICULTY | 2 | `.` | `block.difficulty` | | difficulty of current block |
+| 45 | GASLIMIT | 2 | `.` | `block.gaslimit` | | gas limit of current block |
+| 46 | CHAINID | 2 | `.` | `chain_id` | | push current [chain id](https://eips.ethereum.org/EIPS/eip-155) onto stack |
+| 47 | SELFBALANCE | 5 | `.` | `address(this).balance` | | balance of executing contract, in wei |
+| 48 | BASEFEE | 2 | `.` | `block.basefee` | | base fee of current block |
| 49-4F | _invalid_ |
-| 50 | POP | 2 | `_anon` | `.` | | remove item from top of stack and discard it |
-| 51 | MLOAD | 3[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost` | `mem[ost:ost+32]` | | read word from memory at offset `ost` |
-| 52 | MSTORE | 3[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, val` | `.` | mem[ost:ost+32] := val | write a word to memory |
-| 53 | MSTORE8 | 3[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, val` | `.` | mem[ost] := val && 0xFF | write a single byte to memory |
-| 54 | SLOAD | [A6](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a6-sload) | `key` | `storage[key]` | | read word from storage |
-| 55 | SSTORE | [A7](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a7-sstore) | `key, val` | `.` | storage[key] := val | write word to storage |
-| 56 | JUMP | 8 | `dst` | `.` | | `$pc := dst` mark that `pc` is only assigned if `dst` is a valid jumpdest |
-| 57 | JUMPI | 10 | `dst, condition` | `.` | | `$pc := condition ? dst : $pc + 1` |
-| 58 | PC | 2 | `.` | `$pc` | | program counter |
-| 59 | MSIZE | 2 | `.` | `len(mem)` | | size of memory in current execution context, in bytes |
-| 5A | GAS | 2 | `.` | `gasRemaining` | |
-| 5B | JUMPDEST | 1 | | | mark valid jump destination | a valid jump destination for example a jump destination not inside the push data |
+| 50 | POP | 2 | `_anon` | `.` | | remove item from top of stack and discard it |
+| 51 | MLOAD | 3[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost` | `mem[ost:ost+32]` | | read word from memory at offset `ost` |
+| 52 | MSTORE | 3[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, val` | `.` | mem[ost:ost+32] := val | write a word to memory |
+| 53 | MSTORE8 | 3[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, val` | `.` | mem[ost] := val && 0xFF | write a single byte to memory |
+| 54 | SLOAD | [A6](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a6-sload) | `key` | `storage[key]` | | read word from storage |
+| 55 | SSTORE | [A7](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a7-sstore) | `key, val` | `.` | storage[key] := val | write word to storage |
+| 56 | JUMP | 8 | `dst` | `.` | | `$pc := dst` mark that `pc` is only assigned if `dst` is a valid jumpdest |
+| 57 | JUMPI | 10 | `dst, condition` | `.` | | `$pc := condition ? dst : $pc + 1` |
+| 58 | PC | 2 | `.` | `$pc` | | program counter |
+| 59 | MSIZE | 2 | `.` | `len(mem)` | | size of memory in current execution context, in bytes |
+| 5A | GAS | 2 | `.` | `gasRemaining` | |
+| 5B | JUMPDEST | 1 | | | mark valid jump destination | a valid jump destination for example a jump destination not inside the push data |
| 5C-5F | _invalid_ |
-| 60 | PUSH1 | 3 | `.` | `uint8` | | push 1-byte value onto stack |
-| 61 | PUSH2 | 3 | `.` | `uint16` | | push 2-byte value onto stack |
-| 62 | PUSH3 | 3 | `.` | `uint24` | | push 3-byte value onto stack |
-| 63 | PUSH4 | 3 | `.` | `uint32` | | push 4-byte value onto stack |
-| 64 | PUSH5 | 3 | `.` | `uint40` | | push 5-byte value onto stack |
-| 65 | PUSH6 | 3 | `.` | `uint48` | | push 6-byte value onto stack |
-| 66 | PUSH7 | 3 | `.` | `uint56` | | push 7-byte value onto stack |
-| 67 | PUSH8 | 3 | `.` | `uint64` | | push 8-byte value onto stack |
-| 68 | PUSH9 | 3 | `.` | `uint72` | | push 9-byte value onto stack |
-| 69 | PUSH10 | 3 | `.` | `uint80` | | push 10-byte value onto stack |
-| 6A | PUSH11 | 3 | `.` | `uint88` | | push 11-byte value onto stack |
-| 6B | PUSH12 | 3 | `.` | `uint96` | | push 12-byte value onto stack |
-| 6C | PUSH13 | 3 | `.` | `uint104` | | push 13-byte value onto stack |
-| 6D | PUSH14 | 3 | `.` | `uint112` | | push 14-byte value onto stack |
-| 6E | PUSH15 | 3 | `.` | `uint120` | | push 15-byte value onto stack |
-| 6F | PUSH16 | 3 | `.` | `uint128` | | push 16-byte value onto stack |
-| 70 | PUSH17 | 3 | `.` | `uint136` | | push 17-byte value onto stack |
-| 71 | PUSH18 | 3 | `.` | `uint144` | | push 18-byte value onto stack |
-| 72 | PUSH19 | 3 | `.` | `uint152` | | push 19-byte value onto stack |
-| 73 | PUSH20 | 3 | `.` | `uint160` | | push 20-byte value onto stack |
-| 74 | PUSH21 | 3 | `.` | `uint168` | | push 21-byte value onto stack |
-| 75 | PUSH22 | 3 | `.` | `uint176` | | push 22-byte value onto stack |
-| 76 | PUSH23 | 3 | `.` | `uint184` | | push 23-byte value onto stack |
-| 77 | PUSH24 | 3 | `.` | `uint192` | | push 24-byte value onto stack |
-| 78 | PUSH25 | 3 | `.` | `uint200` | | push 25-byte value onto stack |
-| 79 | PUSH26 | 3 | `.` | `uint208` | | push 26-byte value onto stack |
-| 7A | PUSH27 | 3 | `.` | `uint216` | | push 27-byte value onto stack |
-| 7B | PUSH28 | 3 | `.` | `uint224` | | push 28-byte value onto stack |
-| 7C | PUSH29 | 3 | `.` | `uint232` | | push 29-byte value onto stack |
-| 7D | PUSH30 | 3 | `.` | `uint240` | | push 30-byte value onto stack |
-| 7E | PUSH31 | 3 | `.` | `uint248` | | push 31-byte value onto stack |
-| 7F | PUSH32 | 3 | `.` | `uint256` | | push 32-byte value onto stack |
-| 80 | DUP1 | 3 | `a` | `a, a` | | clone 1st value on stack |
-| 81 | DUP2 | 3 | `_, a` | `a, _, a` | | clone 2nd value on stack |
-| 82 | DUP3 | 3 | `_, _, a` | `a, _, _, a` | | clone 3rd value on stack |
-| 83 | DUP4 | 3 | `_, _, _, a` | `a, _, _, _, a` | | clone 4th value on stack |
-| 84 | DUP5 | 3 | `..., a` | `a, ..., a` | | clone 5th value on stack |
-| 85 | DUP6 | 3 | `..., a` | `a, ..., a` | | clone 6th value on stack |
-| 86 | DUP7 | 3 | `..., a` | `a, ..., a` | | clone 7th value on stack |
-| 87 | DUP8 | 3 | `..., a` | `a, ..., a` | | clone 8th value on stack |
-| 88 | DUP9 | 3 | `..., a` | `a, ..., a` | | clone 9th value on stack |
-| 89 | DUP10 | 3 | `..., a` | `a, ..., a` | | clone 10th value on stack |
-| 8A | DUP11 | 3 | `..., a` | `a, ..., a` | | clone 11th value on stack |
-| 8B | DUP12 | 3 | `..., a` | `a, ..., a` | | clone 12th value on stack |
-| 8C | DUP13 | 3 | `..., a` | `a, ..., a` | | clone 13th value on stack |
-| 8D | DUP14 | 3 | `..., a` | `a, ..., a` | | clone 14th value on stack |
-| 8E | DUP15 | 3 | `..., a` | `a, ..., a` | | clone 15th value on stack |
-| 8F | DUP16 | 3 | `..., a` | `a, ..., a` | | clone 16th value on stack |
-| 90 | SWAP1 | 3 | `a, b` | `b, a` | |
-| 91 | SWAP2 | 3 | `a, _, b` | `b, _, a` | |
-| 92 | SWAP3 | 3 | `a, _, _, b` | `b, _, _, a` | |
-| 93 | SWAP4 | 3 | `a, _, _, _, b` | `b, _, _, _, a` | |
-| 94 | SWAP5 | 3 | `a, ..., b` | `b, ..., a` | |
-| 95 | SWAP6 | 3 | `a, ..., b` | `b, ..., a` | |
-| 96 | SWAP7 | 3 | `a, ..., b` | `b, ..., a` | |
-| 97 | SWAP8 | 3 | `a, ..., b` | `b, ..., a` | |
-| 98 | SWAP9 | 3 | `a, ..., b` | `b, ..., a` | |
-| 99 | SWAP10 | 3 | `a, ..., b` | `b, ..., a` | |
-| 9A | SWAP11 | 3 | `a, ..., b` | `b, ..., a` | |
-| 9B | SWAP12 | 3 | `a, ..., b` | `b, ..., a` | |
-| 9C | SWAP13 | 3 | `a, ..., b` | `b, ..., a` | |
-| 9D | SWAP14 | 3 | `a, ..., b` | `b, ..., a` | |
-| 9E | SWAP15 | 3 | `a, ..., b` | `b, ..., a` | |
-| 9F | SWAP16 | 3 | `a, ..., b` | `b, ..., a` | |
-| A0 | LOG0 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len` | `.` | | LOG0(memory[ost:ost+len-1]) |
-| A1 | LOG1 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0` | `.` | | LOG1(memory[ost:ost+len-1], topic0) |
-| A2 | LOG2 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0, topic1` | `.` | | LOG1(memory[ost:ost+len-1], topic0, topic1) |
-| A3 | LOG3 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0, topic1, topic2` | `.` | | LOG1(memory[ost:ost+len-1], topic0, topic1, topic2) |
-| A4 | LOG4 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0, topic1, topic2, topic3` | `.` | | LOG1(memory[ost:ost+len-1], topic0, topic1, topic2, topic3) |
+| 60 | PUSH1 | 3 | `.` | `uint8` | | push 1-byte value onto stack |
+| 61 | PUSH2 | 3 | `.` | `uint16` | | push 2-byte value onto stack |
+| 62 | PUSH3 | 3 | `.` | `uint24` | | push 3-byte value onto stack |
+| 63 | PUSH4 | 3 | `.` | `uint32` | | push 4-byte value onto stack |
+| 64 | PUSH5 | 3 | `.` | `uint40` | | push 5-byte value onto stack |
+| 65 | PUSH6 | 3 | `.` | `uint48` | | push 6-byte value onto stack |
+| 66 | PUSH7 | 3 | `.` | `uint56` | | push 7-byte value onto stack |
+| 67 | PUSH8 | 3 | `.` | `uint64` | | push 8-byte value onto stack |
+| 68 | PUSH9 | 3 | `.` | `uint72` | | push 9-byte value onto stack |
+| 69 | PUSH10 | 3 | `.` | `uint80` | | push 10-byte value onto stack |
+| 6A | PUSH11 | 3 | `.` | `uint88` | | push 11-byte value onto stack |
+| 6B | PUSH12 | 3 | `.` | `uint96` | | push 12-byte value onto stack |
+| 6C | PUSH13 | 3 | `.` | `uint104` | | push 13-byte value onto stack |
+| 6D | PUSH14 | 3 | `.` | `uint112` | | push 14-byte value onto stack |
+| 6E | PUSH15 | 3 | `.` | `uint120` | | push 15-byte value onto stack |
+| 6F | PUSH16 | 3 | `.` | `uint128` | | push 16-byte value onto stack |
+| 70 | PUSH17 | 3 | `.` | `uint136` | | push 17-byte value onto stack |
+| 71 | PUSH18 | 3 | `.` | `uint144` | | push 18-byte value onto stack |
+| 72 | PUSH19 | 3 | `.` | `uint152` | | push 19-byte value onto stack |
+| 73 | PUSH20 | 3 | `.` | `uint160` | | push 20-byte value onto stack |
+| 74 | PUSH21 | 3 | `.` | `uint168` | | push 21-byte value onto stack |
+| 75 | PUSH22 | 3 | `.` | `uint176` | | push 22-byte value onto stack |
+| 76 | PUSH23 | 3 | `.` | `uint184` | | push 23-byte value onto stack |
+| 77 | PUSH24 | 3 | `.` | `uint192` | | push 24-byte value onto stack |
+| 78 | PUSH25 | 3 | `.` | `uint200` | | push 25-byte value onto stack |
+| 79 | PUSH26 | 3 | `.` | `uint208` | | push 26-byte value onto stack |
+| 7A | PUSH27 | 3 | `.` | `uint216` | | push 27-byte value onto stack |
+| 7B | PUSH28 | 3 | `.` | `uint224` | | push 28-byte value onto stack |
+| 7C | PUSH29 | 3 | `.` | `uint232` | | push 29-byte value onto stack |
+| 7D | PUSH30 | 3 | `.` | `uint240` | | push 30-byte value onto stack |
+| 7E | PUSH31 | 3 | `.` | `uint248` | | push 31-byte value onto stack |
+| 7F | PUSH32 | 3 | `.` | `uint256` | | push 32-byte value onto stack |
+| 80 | DUP1 | 3 | `a` | `a, a` | | clone 1st value on stack |
+| 81 | DUP2 | 3 | `_, a` | `a, _, a` | | clone 2nd value on stack |
+| 82 | DUP3 | 3 | `_, _, a` | `a, _, _, a` | | clone 3rd value on stack |
+| 83 | DUP4 | 3 | `_, _, _, a` | `a, _, _, _, a` | | clone 4th value on stack |
+| 84 | DUP5 | 3 | `..., a` | `a, ..., a` | | clone 5th value on stack |
+| 85 | DUP6 | 3 | `..., a` | `a, ..., a` | | clone 6th value on stack |
+| 86 | DUP7 | 3 | `..., a` | `a, ..., a` | | clone 7th value on stack |
+| 87 | DUP8 | 3 | `..., a` | `a, ..., a` | | clone 8th value on stack |
+| 88 | DUP9 | 3 | `..., a` | `a, ..., a` | | clone 9th value on stack |
+| 89 | DUP10 | 3 | `..., a` | `a, ..., a` | | clone 10th value on stack |
+| 8A | DUP11 | 3 | `..., a` | `a, ..., a` | | clone 11th value on stack |
+| 8B | DUP12 | 3 | `..., a` | `a, ..., a` | | clone 12th value on stack |
+| 8C | DUP13 | 3 | `..., a` | `a, ..., a` | | clone 13th value on stack |
+| 8D | DUP14 | 3 | `..., a` | `a, ..., a` | | clone 14th value on stack |
+| 8E | DUP15 | 3 | `..., a` | `a, ..., a` | | clone 15th value on stack |
+| 8F | DUP16 | 3 | `..., a` | `a, ..., a` | | clone 16th value on stack |
+| 90 | SWAP1 | 3 | `a, b` | `b, a` | |
+| 91 | SWAP2 | 3 | `a, _, b` | `b, _, a` | |
+| 92 | SWAP3 | 3 | `a, _, _, b` | `b, _, _, a` | |
+| 93 | SWAP4 | 3 | `a, _, _, _, b` | `b, _, _, _, a` | |
+| 94 | SWAP5 | 3 | `a, ..., b` | `b, ..., a` | |
+| 95 | SWAP6 | 3 | `a, ..., b` | `b, ..., a` | |
+| 96 | SWAP7 | 3 | `a, ..., b` | `b, ..., a` | |
+| 97 | SWAP8 | 3 | `a, ..., b` | `b, ..., a` | |
+| 98 | SWAP9 | 3 | `a, ..., b` | `b, ..., a` | |
+| 99 | SWAP10 | 3 | `a, ..., b` | `b, ..., a` | |
+| 9A | SWAP11 | 3 | `a, ..., b` | `b, ..., a` | |
+| 9B | SWAP12 | 3 | `a, ..., b` | `b, ..., a` | |
+| 9C | SWAP13 | 3 | `a, ..., b` | `b, ..., a` | |
+| 9D | SWAP14 | 3 | `a, ..., b` | `b, ..., a` | |
+| 9E | SWAP15 | 3 | `a, ..., b` | `b, ..., a` | |
+| 9F | SWAP16 | 3 | `a, ..., b` | `b, ..., a` | |
+| A0 | LOG0 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len` | `.` | | LOG0(memory[ost:ost+len-1]) |
+| A1 | LOG1 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0` | `.` | | LOG1(memory[ost:ost+len-1], topic0) |
+| A2 | LOG2 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0, topic1` | `.` | | LOG1(memory[ost:ost+len-1], topic0, topic1) |
+| A3 | LOG3 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0, topic1, topic2` | `.` | | LOG1(memory[ost:ost+len-1], topic0, topic1, topic2) |
+| A4 | LOG4 | [A8](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a8-log-operations) | `ost, len, topic0, topic1, topic2, topic3` | `.` | | LOG1(memory[ost:ost+len-1], topic0, topic1, topic2, topic3) |
| A5-EF | _invalid_ |
-| F0 | CREATE | [A9](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a9-create-operations) | `val, ost, len` | `addr` | | addr = keccak256(rlp([address(this), this.nonce])) |
-| F1 | CALL | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | gas, addr, val, argOst, argLen, retOst, retLen | `success` | mem[retOst:retOst+retLen-1] := returndata |
-| F2 | CALLCODE | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | `gas, addr, val, argOst, argLen, retOst, retLen` | `success` | mem[retOst:retOst+retLen-1] = returndata | same as DELEGATECALL, but does not propagate original msg.sender and msg.value |
-| F3 | RETURN | 0[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, len` | `.` | | return mem[ost:ost+len-1] |
-| F4 | DELEGATECALL | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | `gas, addr, argOst, argLen, retOst, retLen` | `success` | mem[retOst:retOst+retLen-1] := returndata |
-| F5 | CREATE2 | [A9](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a9-create-operations) | `val, ost, len, salt` | `addr` | | addr = keccak256(0xff ++ address(this) ++ salt ++ keccak256(mem[ost:ost+len-1]))[12:] |
+| F0 | CREATE | [A9](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a9-create-operations) | `val, ost, len` | `addr` | | addr = keccak256(rlp([address(this), this.nonce])) |
+| F1 | CALL | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | gas, addr, val, argOst, argLen, retOst, retLen | `success` | mem[retOst:retOst+retLen-1] := returndata |
+| F2 | CALLCODE | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | `gas, addr, val, argOst, argLen, retOst, retLen` | `success` | mem[retOst:retOst+retLen-1] = returndata | same as DELEGATECALL, but does not propagate original msg.sender and msg.value |
+| F3 | RETURN | 0[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, len` | `.` | | return mem[ost:ost+len-1] |
+| F4 | DELEGATECALL | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | `gas, addr, argOst, argLen, retOst, retLen` | `success` | mem[retOst:retOst+retLen-1] := returndata |
+| F5 | CREATE2 | [A9](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a9-create-operations) | `val, ost, len, salt` | `addr` | | addr = keccak256(0xff ++ address(this) ++ salt ++ keccak256(mem[ost:ost+len-1]))[12:] |
| F6-F9 | _invalid_ |
-| FA | STATICCALL | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | `gas, addr, argOst, argLen, retOst, retLen` | `success` | mem[retOst:retOst+retLen-1] := returndata |
+| FA | STATICCALL | [AA](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#aa-call-operations) | `gas, addr, argOst, argLen, retOst, retLen` | `success` | mem[retOst:retOst+retLen-1] := returndata |
| FB-FC | _invalid_ |
-| FD | REVERT | 0[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, len` | `.` | | revert(mem[ost:ost+len-1]) |
-| FE | INVALID | [AF](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#af-invalid) | | | designated invalid opcode - [EIP-141](https://eips.ethereum.org/EIPS/eip-141) |
-| FF | SELFDESTRUCT | [AB](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#ab-selfdestruct) | `addr` | `.` | | | destroy contract and sends all funds to `addr` |
+| FD | REVERT | 0[\*](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#a0-1-memory-expansion) | `ost, len` | `.` | | revert(mem[ost:ost+len-1]) |
+| FE | INVALID | [AF](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#af-invalid) | | | designated invalid opcode - [EIP-141](https://eips.ethereum.org/EIPS/eip-141) |
+| FF | SELFDESTRUCT | [AB](https://github.com/wolflo/evm-opcodes/blob/main/gas.md#ab-selfdestruct) | `addr` | `.` | | | destroy contract and sends all funds to `addr` |
diff --git a/src/content/developers/docs/gas/index.md b/src/content/developers/docs/gas/index.md
index c259b75b873..8f75f47c640 100644
--- a/src/content/developers/docs/gas/index.md
+++ b/src/content/developers/docs/gas/index.md
@@ -3,7 +3,6 @@ title: Gas and fees
description:
lang: en
sidebar: true
-preMergeBanner: true
---
Gas is essential to the Ethereum network. It is the fuel that allows it to operate, in the same way that a car needs gasoline to run.
@@ -33,30 +32,16 @@ In the transaction, the gas limit is 21,000 units, and the gas price is 200 gwei
Total fee would have been: `Gas units (limit) * Gas price per unit`
i.e `21,000 * 200 = 4,200,000 gwei` or 0.0042 ETH
-When Alice sent the money, 1.0042 ETH would be deducted from Alice's account.
-Bob would be credited 1.0000 ETH.
-Miner would receive 0.0042 ETH.
-
-This video offers a concise overview of gas and why it exists:
-
-
+Let's say Jordan has to pay Taylor 1 ETH. In the transaction, the gas limit is 21,000 units and the base fee is 10 gwei. Jordan includes a tip of 2 gwei.
## After the London upgrade {#post-london}
-[The London Upgrade](/history/#london) was implemented on August 5th, 2021, to make transacting on Ethereum more predictable for users by overhauling Ethereum's transaction-fee-mechanism. The high-level benefits introduced by this change include better transaction fee estimation, generally quicker transaction inclusion, and offsetting the ETH issuance by burning a percentage of transaction fees.
-
-Starting with the London network upgrade, every block has a base fee, the minimum price per unit of gas for inclusion in this block, calculated by the network based on demand for block space. As the base fee of the transaction fee is burnt, users are also expected to set a tip (priority fee) in their transactions. The tip compensates miners for executing and propagating user transactions in blocks and is expected to be set automatically by most wallets.
-
-Calculating the total transaction fee works as follows: `Gas units (limit) * (Base fee + Tip)`
-
-Let's say Jordan has to pay Taylor 1 ETH. In the transaction, the gas limit is 21,000 units and the base fee is 100 gwei. Jordan includes a tip of 10 gwei.
-
-Using the formula above we can calculate this as `21,000 * (100 + 10) = 2,310,000 gwei` or 0.00231 ETH.
+`21,000 * (10 + 2) = 252,000 gwei` or 0.000252 ETH.
-When Jordan sends the money, 1.00231 ETH will be deducted from Jordan's account.
+When Jordan sends the money, 1.000252 ETH will be deducted from Jordan's account.
Taylor will be credited 1.0000 ETH.
-Miner receives the tip of 0.00021 ETH.
-Base fee of 0.0021 ETH is burned.
+Validator receives the tip of 0.000042 ETH.
+Base fee of 0.00021 ETH is burned.
Additionally, Jordan can also set a max fee (`maxFeePerGas`) for the transaction. The difference between the max fee and the actual fee is refunded to Jordan, i.e. `refund = max fee - (base fee + priority fee)`. Jordan can set a maximum amount to pay for the transaction to execute and not worry about overpaying "beyond" the base fee when the transaction is executed.
diff --git a/src/content/developers/docs/intro-to-ether/index.md b/src/content/developers/docs/intro-to-ether/index.md
index e0d4a255bb2..61f61f91dd5 100644
--- a/src/content/developers/docs/intro-to-ether/index.md
+++ b/src/content/developers/docs/intro-to-ether/index.md
@@ -3,7 +3,6 @@ title: Intro to ether
description: A developer's introduction to the ether cryptocurrency.
lang: en
sidebar: true
-preMergeBanner: true
---
## Prerequisites {#prerequisites}
@@ -34,7 +33,7 @@ It is [common](https://www.reuters.com/article/us-crypto-currencies-lending-insi
Minting is the process in which new ether gets created on the Ethereum ledger. The underlying Ethereum protocol creates the new ether, and it is not possible for a user to create ether.
-Ether is minted when a new block is created on the Ethereum blockchain. As an incentive to build blocks, the protocol grants a reward in each block, incrementing the balance of an address set by the block producer. The block reward has changed over time, and today it is 2 ETH per block. After the merge issuance to each validator depends upon the amount of ether they have staked and their performance.
+Ether is minted as a reward for each block proposed and at every epoch checkpoint for other validator activity related to reaching consensus. The total amount issued depends on the number of validators and how much ether they have staked. This total issuance is divided equally among validators in the ideal case that all validators are honest and online, but in reality, it varies based on validator performance. About 1/8 of the total issuance goes to the block proposer; the remainder is distributed across the other validators. Block proposers also receive tips from transaction fees and MEV-related income, but these come from recycled ether, not new issuance.
## Burning ether {#burning-ether}
diff --git a/src/content/developers/docs/intro-to-ethereum/index.md b/src/content/developers/docs/intro-to-ethereum/index.md
index f067ec4e108..b2b78a530c9 100644
--- a/src/content/developers/docs/intro-to-ethereum/index.md
+++ b/src/content/developers/docs/intro-to-ethereum/index.md
@@ -3,7 +3,6 @@ title: Intro to Ethereum
description: A dapp developer's introduction to the core concepts of Ethereum.
lang: en
sidebar: true
-preMergeBanner: true
---
## What is a blockchain? {#what-is-a-blockchain}
@@ -16,15 +15,7 @@ A blockchain is a public database that is updated and shared across many compute
Every computer in the network must agree upon each new block and the chain as a whole. These computers are known as "nodes". Nodes ensure everyone interacting with the blockchain has the same data. To accomplish this distributed agreement, blockchains need a consensus mechanism.
-Ethereum currently uses a [proof-of-work](/developers/docs/consensus-mechanisms/pow/) consensus mechanism. This means that anyone who wants to add new blocks to the chain must solve a difficult puzzle that requires a lot of computing power. Solving the puzzle "proves" that you have done the "work" by using computational resources. Doing this is known as [mining](/developers/docs/consensus-mechanisms/pow/mining/). Mining is typically brute force trial and error, but successfully adding a block is rewarded in ETH.
-
-New blocks are broadcast to the nodes in the network, checked and verified, thus updating the state of the blockchain for everyone.
-
-So to summarize, when you send ETH to someone, the transaction must be added to the block which will get mined. The updated state is then shared with the entire network.
-
-Watch Austin walk you through blockchains:
-
-
+Ethereum uses a [proof-of-stake-based consensus mechanism](/developers/docs/consensus-mechanisms/pos/). Anyone who wants to add new blocks to the chain must stake at least 32 ETH into the deposit contract and run validator software. They then can be randomly selected to propose blocks that other validators check and add to the blockchain. In this model, there is usually only one chain, but network latency and dishonest behavior can cause multiple blocks to exist at the same position near the head of the chain. To resolve this, a fork-choice algorithm selects one canonical set of blocks. The blocks selected are the ones that form the heaviest possible chain, where 'heavy' refers to the number of validators that have endorsed the blocks (weighted by the ETH they have staked). There is a system of rewards and penalties that strongly incentivize participants to be honest and online as much as possible.
If you want to see how blockchain hashes data and then the previous block references all the past blocks, be sure to check out [this demo](https://andersbrownworth.com/blockchain/blockchain) by Anders Brownworth and watch the accompanying video below.
@@ -34,6 +25,8 @@ Watch Anders explain hashes in blockchains:
## What is Ethereum? {#what-is-ethereum}
+Ethereum is a blockchain with a computer embedded in it. It is the foundation for building apps and organizations in a decentralized, permissionless, censorship-resistant way.
+
In the Ethereum universe, there is a single, canonical computer (called the Ethereum Virtual Machine, or EVM) whose state everyone on the Ethereum network agrees on. Everyone who participates in the Ethereum network (every Ethereum node) keeps a copy of the state of this computer. Additionally, any participant can broadcast a request for this computer to perform arbitrary computation. Whenever such a request is broadcast, other participants on the network verify, validate, and carry out ("execute") the computation. This execution causes a state change in the EVM, which is committed and propagated throughout the entire network.
Requests for computation are called transaction requests; the record of all transactions and the EVM's present state gets stored on the blockchain, which in turn is stored and agreed upon by all nodes.
@@ -42,11 +35,13 @@ Cryptographic mechanisms ensure that once transactions are verified as valid and
## What is ether? {#what-is-ether}
-**Ether (ETH)** is the native cryptocurrency of Ethereum. The purpose of ether is to allow for a market for computation. Such a market provides an economic incentive for participants to verify and execute transaction requests and provide computational resources to the network.
+**Ether (ETH)** is the native cryptocurrency of Ethereum. The purpose of ETH is to allow for a market for computation. Such a market provides an economic incentive for participants to verify and execute transaction requests and provide computational resources to the network.
+
+Any participant who broadcasts a transaction request must also offer some amount of ETH to the network as a bounty. The network will award this bounty to whoever eventually does the work of verifying the transaction, executing it, committing it to the blockchain, and broadcasting it to the network.
-Any participant who broadcasts a transaction request must also offer some amount of ether to the network as a bounty. This bounty will be awarded to whoever eventually does the work of verifying the transaction, executing it, committing it to the blockchain, and broadcasting it to the network.
+The amount of ETH paid corresponds to the time required to do the computation. These bounties also prevent malicious participants from intentionally clogging the network by requesting the execution of infinite computation or other resource-intensive scripts, as these participants must pay for computation time.
-The amount of ether paid corresponds to the time required to do the computation. These bounties also prevent malicious participants from intentionally clogging the network by requesting the execution of infinite computation or other resource-intensive scripts, as these participants must pay for computation time.
+ETH is also used to provide crypto-economic security to the network in three main ways: 1) it is used as a means to reward validators who propose blocks or call out dishonest behavior by other validators; 2) It is staked by validators, acting as collateral against dishonest behavior—if validators attempt to misbehave their ETH can be destroyed; 3) it is used to weight 'votes' for newly proposed blocks, feeding into the fork-choice part of the consensus mechanism.
## What are smart contracts? {#what-are-smart-contracts}
diff --git a/src/content/developers/docs/mev/index.md b/src/content/developers/docs/mev/index.md
index 75593704f4a..9357a53c0cc 100644
--- a/src/content/developers/docs/mev/index.md
+++ b/src/content/developers/docs/mev/index.md
@@ -3,26 +3,25 @@ title: Maximal extractable value (MEV)
description: An introduction to maximal extractable value (MEV)
lang: en
sidebar: true
-preMergeBanner: true
---
Maximal extractable value (MEV) refers to the maximum value that can be extracted from block production in excess of the standard block reward and gas fees by including, excluding, and changing the order of transactions in a block.
-### Miner extractable value
+### Miner extractable value {#miner-extractable-value}
-This concept was first applied in the context of [proof-of-work](/developers/docs/consensus-mechanisms/pow/), and was initially referred to as "miner extractable value". This is because in proof-of-work, miners control transaction inclusion, exclusion, and ordering. However, after the transition to proof-of-stake via [The Merge](/upgrades/merge) validators will be responsible for these roles, and mining will no longer be applicable. The value extraction methods here will still persist after this transition, and thus the term "miner extractable value" is no longer valid. "Maximal extractable value" is now used as a more inclusive replacement.
+Maximal extractable value was first applied in the context of [proof-of-work](/developers/docs/consensus-mechanisms/pow/), and initially referred to as "miner extractable value". This is because in proof-of-work, miners control transaction inclusion, exclusion, and ordering. However, since the transition to proof-of-stake via [The Merge](/upgrades/merge) validators have been responsible for these roles, and mining is no longer part of the Ethereum protocol. The value extraction methods still exist, though, so the term "Maximal extractable value" is now used instead.
## Prerequisites {#prerequisites}
-Make sure you're familiar with [transactions](/developers/docs/transactions/), [blocks](/developers/docs/blocks/), [gas](/developers/docs/gas/), and [mining](/developers/docs/consensus-mechanisms/pow/mining/). Familiarity with [dapps](/dapps/) and [DeFi](/defi/) is helpful as well.
+Make sure you're familiar with [transactions](/developers/docs/transactions/), [blocks](/developers/docs/blocks/), [proof-of-stake](/developers/docs/consensus-mechanisms/pos) and [gas](/developers/docs/gas/). Familiarity with [dapps](/dapps/) and [DeFi](/defi/) is helpful as well.
## MEV extraction {#mev-extraction}
-In theory MEV accrues entirely to miners/validators because they are the only party that can guarantee the execution of a profitable MEV opportunity. In practice, however, a large portion of MEV is extracted by independent network participants referred to as "searchers." Searchers run complex algorithms on blockchain data to detect profitable MEV opportunities and have bots to automatically submit those profitable transactions to the network.
+In theory MEV accrues entirely to validators because they are the only party that can guarantee the execution of a profitable MEV opportunity. In practice, however, a large portion of MEV is extracted by independent network participants referred to as "searchers." Searchers run complex algorithms on blockchain data to detect profitable MEV opportunities and have bots to automatically submit those profitable transactions to the network.
-Miners/validators do get a portion of the full MEV amount anyway because searchers are willing to pay high gas fees (which go to the miner/validator) in exchange for higher likelihood of inclusion of their profitable transactions in a block. Assuming searchers are economically rational, the gas fee that a searcher is willing to pay will be an amount up to 100% of the searcher's MEV (because if the gas fee was higher, the searcher would lose money).
+Validators do get a portion of the full MEV amount anyway because searchers are willing to pay high gas fees (which go to the validator) in exchange for higher likelihood of inclusion of their profitable transactions in a block. Assuming searchers are economically rational, the gas fee that a searcher is willing to pay will be an amount up to 100% of the searcher's MEV (because if the gas fee was higher, the searcher would lose money).
-With that, for some highly competitive MEV opportunities, such as [DEX arbitrage](#mev-examples-dex-arbitrage), searchers may have to pay 90% or even more of their total MEV revenue in gas fees to the miner/validator because so many people want to run the same profitable arbitrage trade. This is because the only way to guarantee that their arbitrage transaction runs is if they submit the transaction with the highest gas price.
+With that, for some highly competitive MEV opportunities, such as [DEX arbitrage](#mev-examples-dex-arbitrage), searchers may have to pay 90% or even more of their total MEV revenue in gas fees to the validator because so many people want to run the same profitable arbitrage trade. This is because the only way to guarantee that their arbitrage transaction runs is if they submit the transaction with the highest gas price.
### Gas golfing {#mev-extraction-gas-golfing}
@@ -36,9 +35,7 @@ Rather than programming complex algorithms to detect profitable MEV opportunitie
### Flashbots {#mev-extraction-flashbots}
-Flashbots is an independent project which extends the go-ethereum client with a service that allows searchers to submit MEV transactions to miners without revealing them to the public mempool. This prevents transactions from being frontrun by generalized frontrunners.
-
-As of this writing, a significant portion of MEV transactions is routed through Flashbots, meaning generalized frontrunners aren't as effective as they used to be.
+Flashbots is an independent project which extends execution clients with a service that allows searchers to submit MEV transactions to validators without revealing them to the public mempool. This prevents transactions from being frontrun by generalized frontrunners.
## MEV examples {#mev-examples}
@@ -106,7 +103,7 @@ At the application layer, some forms of MEV, like sandwich trading, result in an
At the network layer, generalized frontrunners and the gas-price auctions they often engage in (when two or more frontrunners compete for their transaction to be included in the next block by progressively raising their own transactions' gas price) result in network congestion and high gas prices for everyone else trying to run regular transactions.
-Beyond what's happening _within_ blocks, MEV can have deleterious effects _between_ blocks. If the MEV available in a block significantly exceeds the standard block reward, miners may be incentivized to remine blocks and capture the MEV for themselves, causing blockchain re-organization and consensus instability.
+Beyond what's happening _within_ blocks, MEV can have deleterious effects _between_ blocks. If the MEV available in a block significantly exceeds the standard block reward, validators may be incentivized to reorg blocks and capture the MEV for themselves, causing blockchain re-organization and consensus instability.
This possibility of blockchain re-organization has been [previously explored on the Bitcoin blockchain](https://dl.acm.org/doi/10.1145/2976749.2978408). As Bitcoin's block reward halves and transaction fees make up a greater and greater portion of the block reward, situations arise where it becomes economically rational for miners to give up the next block's reward and instead remine past blocks with higher fees. With the growth of MEV, the same sort of situation could occur in Ethereum, threatening the integrity of the blockchain.
@@ -114,12 +111,13 @@ This possibility of blockchain re-organization has been [previously explored on
MEV extraction ballooned in early 2021, resulting in extremely high gas prices in the first few months of the year. The emergence of Flashbots's MEV relay has reduced the effectiveness of generalized frontrunners and has taken gas price auctions off-chain, lowering gas prices for ordinary users.
-While many searchers are still making good money from MEV, as opportunities become more well-known and more and more searchers compete for the same opportunity, miners/validators will capture more and more total MEV revenue (because the same sort of gas auctions as originally described above also occur in Flashbots, albeit privately, and miners will capture the resulting gas revenue). MEV is also not unique to Ethereum, and as opportunities become more competitive on Ethereum, searchers are moving to alternate blockchains like Binance Smart Chain, where similar MEV opportunities as those on Ethereum exist with less competition.
+While many searchers are still making good money from MEV, as opportunities become more well-known and more and more searchers compete for the same opportunity, validators will capture more and more total MEV revenue (because the same sort of gas auctions as originally described above also occur in Flashbots, albeit privately, and validators will capture the resulting gas revenue). MEV is also not unique to Ethereum, and as opportunities become more competitive on Ethereum, searchers are moving to alternate blockchains like Binance Smart Chain, where similar MEV opportunities as those on Ethereum exist with less competition.
-As DeFi grows and increases in popularity, MEV may soon significantly outweigh the base Ethereum block reward. With that comes a growing possibility of selfish block remining and consensus instability. Some consider this to be an existential threat to Ethereum, and disincentivizing selfish mining is an active area of research in Ethereum protocol theory. One solution currently being explored is [MEV reward smoothing](https://ethresear.ch/t/committee-driven-mev-smoothing/10408).
+On the other hand, the transition from proof-of-work to proof-of-stake and the ongoing effort to scale Ethereum using rollups and sharding all change the MEV landscape in ways that are still somewhat unclear. It is not yet well known how having guaranteed block-proposers known slightly in advance changes the dynamics of MEV extraction compared to the probabilistic model in proof-of-work or how this will be disrupted when [single secret leader election](https://ethresear.ch/t/secret-non-single-leader-election/11789) and [distributed validator technology](https://github.com/ethereum/distributed-validator-specs) get implemented. Similarly, it remains to be seen what MEV opportunities exist when most user activity is ported away from Ethereum and onto its layer 2 rollups and shards.
## Related resources {#related-resources}
+- [Flashbots docs](https://docs.flashbots.net/)
- [Flashbots GitHub](https://github.com/flashbots/pm)
- [MEV-Explore](https://explore.flashbots.net/) _Dashboard and live transaction explorer for MEV transactions_
diff --git a/src/content/developers/docs/networking-layer/index.md b/src/content/developers/docs/networking-layer/index.md
index cd89235fffb..635743dac3d 100644
--- a/src/content/developers/docs/networking-layer/index.md
+++ b/src/content/developers/docs/networking-layer/index.md
@@ -4,14 +4,13 @@ description: An introduction to Ethereum's networking layer.
lang: en
sidebar: true
sidebarDepth: 2
-preMergeBanner: true
---
Ethereum is a peer-to-peer network with thousands of nodes that must be able to communicate with one another using standardized protocols. The "networking layer" is the stack of protocols that allow those nodes to find each other and exchange information. This includes "gossiping" information (one-to-many communication) over the network as well as swapping requests and responses between specific nodes (one-to-one communication). Each node must adhere to specific networking rules to ensure they are sending and receiving the correct information.
-After [The Merge](/upgrades/merge/), there will be two parts of client software (execution clients and consensus clients), each with its own distinct networking stack. As well as communicating with other Ethereum nodes, the execution and consensus clients have to communicate with each other. This page gives an introductory explanation of the protocols that enable this communication.
+There are two parts to the client software (execution clients and consensus clients), each with its own distinct networking stack. As well as communicating with other Ethereum nodes, the execution and consensus clients have to communicate with each other. This page gives an introductory explanation of the protocols that enable this communication.
-**Note that after [The Merge](/upgrades/merge) execution clients will no longer be responsible for gossiping blocks, but they will still gossip transactions over the execution-layer peer-to-peer network. Transactions will be passed to consensus clients via a local RPC connection, where they will be packaged into Beacon blocks. Consensus clients will then gossip Beacon blocks across their p2p network.**
+Execution clients gossip transactions over the execution-layer peer-to-peer network. This requires encrypted communication between authenticated peers. When a validator is selected to propose a block, transactions from the node's local transaction pool will be passed to consensus clients via a local RPC connection, which will be packaged into Beacon blocks. Consensus clients will then gossip Beacon blocks across their p2p network. This requires two separate p2p networks: one connecting execution clients for transaction gossip and one connecting consensus clients for block gossip.
## Prerequisites {#prerequisites}
@@ -73,7 +72,7 @@ Along with the hello messages, the wire protocol can also send a "disconnect" me
#### Wire protocol {#wire-protocol}
-Once peers are connected and an RLPx session has been started, the wire protocol defines how peers communicate. There are three main tasks defined by the wire protocol: chain synchronization, block propagation and transaction exchange. Chain synchronization is the process of validating blocks near the head of the chain, checking their proof-of-work data and re-executing their transactions to ensure their root hashes are correct, then cascading back in history via those blocks' parents, grandparents etc until the whole chain has been downloaded and validated. State sync is a faster alternative that only validates block headers. Block propagation is the process of sending and receiving newly mined blocks. Transaction exchange refers to exchanging pending transactions between nodes so that miners can select some of them for inclusion in the next block. Detailed information about these tasks is available [here](https://github.com/ethereum/devp2p/blob/master/caps/eth.md). Clients that support these sub-protocols expose them via the [JSON-RPC](/developers/docs/apis/json-rpc).
+Once peers are connected, and an RLPx session has been started, the wire protocol defines how peers communicate. Initially, the wire protocol defined three main tasks: chain synchronization, block propagation and transaction exchange. However, once Ethereum switched to proof-of-stake, block propagation and chain synchronization became part of the consensus layer. Transaction exchange is still in the remit of the execution clients. Transaction exchange refers to exchanging pending transactions between nodes so that miners can select some of them for inclusion in the next block. Detailed information about these tasks is available [here](https://github.com/ethereum/devp2p/blob/master/caps/eth.md). Clients that support these sub-protocols expose them via the [JSON-RPC](/developers/docs/apis/json-rpc/).
#### les (light ethereum subprotocol) {#les}
@@ -91,10 +90,6 @@ The [witness protocol](https://github.com/ethereum/devp2p/blob/master/caps/wit.m
Whisper was a protocol that aimed to deliver secure messaging between peers without writing any information to the blockchain. It was part of the DevP2P wire protocol but is now deprecated. Other [related projects](https://wakunetwork.com/) exist with similar aims.
-## Execution layer networking after The Merge {#execution-after-merge}
-
-After the Merge, an Ethereum node will run an execution client and a consensus client. The execution clients will operate similarly to today, but with the proof-of-work consensus and block gossip functionality removed. The EVM, validator deposit contract and selecting/executing transactions from the mempool will still be the domain of the execution client. This means execution clients still need to participate in transaction gossip so that they can manage the transaction mempool. This requires encrypted communication between authenticated peers meaning the networking layer for consensus clients will still be a critical component, including both the discovery protocol and DevP2P layer. Encoding will continue to be predominantly RLP on the execution layer.
-
## The consensus layer {#consensus-layer}
The consensus clients participate in a separate peer-to-peer network with a different specification. Consensus clients need to participate in block gossip so that they can receive new blocks from peers and broadcast them when it is their turn to be block proposer. Similarly to the execution layer, this first requires a discovery protocol so that a node can find peers and establish secure sessions for exchanging blocks, attestations etc.
@@ -125,7 +120,7 @@ SSZ stands for simple serialization. It uses fixed offsets that make it easy to
## Connecting the execution and consensus clients {#connecting-clients}
-After the Merge, both consensus and execution clients will run in parallel. They need to be connected together so that the consensus client can provide instructions to the execution client and the execution client can pass bundles of transactions to the consensus client to include in Beacon blocks. This communication between the two clients can be achieved using a local RPC connection. An API known as the ['Engine-API'](https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md) defines the instructions sent between the two clients. Since both clients sit behind a single network identity, they share a ENR (Ethereum node record) which contains a separate key for each client (eth1 key and eth2 key).
+Both consensus and execution clients run in parallel. They need to be connected so that the consensus client can provide instructions to the execution client, and the execution client can pass bundles of transactions to the consensus client to include in Beacon blocks. The communication between the two clients can be achieved using a local RPC connection. An API known as the ['Engine-API'](https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md) defines the instructions sent between the two clients. Since both clients sit behind a single network identity, they share an ENR (Ethereum node record) which contains a separate key for each client (eth1 key and eth2 key).
A summary of the control flow is shown below, with the relevant networking stack in brackets.
@@ -153,7 +148,7 @@ Once the block has been attested by sufficient validators it is added to the hea
![](cons_client_net_layer.png)
![](exe_client_net_layer.png)
-Network layer schematic for post-merge consensus and execution clients, from [ethresear.ch](https://ethresear.ch/t/eth1-eth2-client-relationship/7248)
+Network layer schematic for consensus and execution clients, from [ethresear.ch](https://ethresear.ch/t/eth1-eth2-client-relationship/7248)
## Further Reading {#further-reading}
diff --git a/src/content/developers/docs/networks/index.md b/src/content/developers/docs/networks/index.md
index bb0e944a878..38048d4deb7 100644
--- a/src/content/developers/docs/networks/index.md
+++ b/src/content/developers/docs/networks/index.md
@@ -3,7 +3,6 @@ title: Networks
description: An overview of Ethereum's networks and where to get testnet ether (ETH) for testing your application.
lang: en
sidebar: true
-preMergeBanner: true
---
Networks are different Ethereum environments you can access for development, testing, or production use cases. Since Ethereum is a protocol, there can be multiple independent "networks" that conform to the protocol without interacting with each other.
@@ -30,15 +29,27 @@ In addition to Mainnet, there are public testnets. These are networks used by pr
You should test any contract code you write on a testnet before deploying to Mainnet. Among dapps that integrate with existing smart contracts, most projects have copies deployed to testnets.
-Most testnets use a proof-of-authority consensus mechanism. This means a small number of nodes are chosen to validate transactions and create new blocks – staking their identity in the process. Testnets do not incentivize proof-of-work mining, which can leave them vulnerable.
+Most testnets started by using a proof-of-authority consensus mechanism. This means a small number of nodes are chosen to validate transactions and create new blocks – staking their identity in the process. Alternatively, some testnets started off using a proof-of-work consensus mechanism with just a few permissioned miners. However, in preparation for [The Merge](/upgrades/merge), these testnets underwent their own transitions to proof-of-stake, offering the opportunity for multiple 'dress-rehearsals' before developers merged Ethereum Mainnet. The Ethereum testnets are now proof-of-stake, just like Ethereum Mainnet.
-As [The Merge](/upgrades/merge) gets closer, more of the public proof-of-work and proof-of-authority testnets are upgrading to proof-of-stake. Swapping their consensus mechanisms acts as a rehearsal for the Ethereum Mainnet merge. Ropsten, Sepolia and Goerli are all expected to be proof-of-stake networks by the end of summer 2022, with Goerli being maintained long term.
+ETH on testnets has no real value; therefore, there are no markets for testnet ETH. Since you need ETH to actually interact with Ethereum, most people get testnet ETH from faucets. Most faucets are webapps where you can input an address which you request ETH to be sent to.
-ETH on testnets has no real value; therefore, there are no markets for testnet ETH. Since you need ETH to actually interact with the Ethereum network, most people get testnet ETH from faucets. Most faucets are web-apps where you can input an address and request ETH to be sent.
+#### Goerli {#goerli}
+
+Goerli is a proof-of-stake testnet. It is expected to be maintained long-term as a stable testnet for application developers. Before its testnet merge, Goerli was a proof-of-authority testnet.
+
+- [Website](https://goerli.net/)
+- [GitHub](https://github.com/goerli/testnet)
+- [Etherscan](https://goerli.etherscan.io)
+
+##### Goerli faucets
+
+- [Goerli faucet](https://faucet.goerli.mudit.blog/)
+- [Chainlink faucet](https://faucets.chain.link/)
+- [Alchemy Goerli Faucet](https://goerlifaucet.com/)
#### Sepolia {#sepolia}
-A proof-of-work testnet; this means it's the best like-for-like representation of Ethereum. Sepolia is expected to undergo The Merge to proof-of-stake in summer 2022. It is not yet certain whether it will then be maintained long term.
+Sepolia is a proof-of-stake testnet. Although Sepolia is still running, it is not currently planned to be maintained long-term. Before undergoing The Merge in June 2022, Sepolia was a proof-of-work testnet.
- [Website](https://sepolia.dev/)
- [GitHub](https://github.com/goerli/sepolia)
@@ -50,25 +61,11 @@ A proof-of-work testnet; this means it's the best like-for-like representation o
- [Sepolia faucet](https://faucet.sepolia.dev/)
- [FaucETH](https://fauceth.komputing.org)
-#### Goerli {#goerli}
-
-A proof-of-authority testnet that works across clients; an ideal testnet for application developers. Goerli will be the final testnet merged to proof-of-stake before Ethereum Mainnet is merged. This is expected to happen in summer 2022. Goerli is expected to be maintained long term as a proof-of-stake testnet.
-
-- [Website](https://goerli.net/)
-- [GitHub](https://github.com/goerli/testnet)
-- [Etherscan](https://goerli.etherscan.io)
-
-##### Goerli faucets
-
-- [Goerli faucet](https://faucet.goerli.mudit.blog/)
-- [Chainlink faucet](https://faucets.chain.link/)
-- [Alchemy Goerli Faucet](https://goerlifaucet.com/)
-
#### Ropsten _(deprecated)_ {#ropsten}
_Note, [the Ropsten testnet is deprecated](https://github.com/ethereum/pm/issues/460) and will no longer receive protocol upgrades. Please consider migrating your applications to Sepolia or Goerli._
-Ropsten was a proof-of-work testnet that went through The Merge to proof-of-stake in May 2022. It can be used to test applications on a merged network, but it is not expected to be maintained long term and is likely to deprecated before summer 2023.
+Ropsten is a proof-of-stake testnet. Ropsten will be deprecated in late 2022. Before undergoing The Merge in May 2022, Ropsten was a proof-of-work testnet.
##### Ropsten faucets
diff --git a/src/content/developers/docs/nodes-and-clients/client-diversity/index.md b/src/content/developers/docs/nodes-and-clients/client-diversity/index.md
index 1d067cba391..f26f4e55692 100644
--- a/src/content/developers/docs/nodes-and-clients/client-diversity/index.md
+++ b/src/content/developers/docs/nodes-and-clients/client-diversity/index.md
@@ -4,14 +4,13 @@ description: A high level explanation of the importance of Ethereum client diver
lang: en
sidebar: true
sidebarDepth: 2
-preMergeBanner: true
---
The behavior of an Ethereum node is controlled by the client software it runs. There are several production-level Ethereum clients, each one developed and maintained in different languages by separate teams. The clients are built to a common spec that ensures the clients seamlessly communicate with each other and have the same functionality and provide an equivalent user experience. However, at the moment the distribution of clients across nodes is not equal enough to realize this network fortification to its full potential. Ideally, users divide roughly equally across the various clients to bring as much client diversity as possible to the network.
## Prerequisites {#prerequisites}
-If you don't already have an understanding of what nodes and clients are, check out [nodes and clients](/developers/docs/nodes-and-clients/). The Beacon Chain is explained [here](/upgrades/beacon-chain/). [Execution](/glossary/#execution-layer) and [consensus](/glossary/#consensus-layer) layers are defined in the glossary.
+If you don't already understand what nodes and clients are, check out [nodes and clients](/developers/docs/nodes-and-clients/). [Execution](/glossary/#execution-layer) and [consensus](/glossary/#consensus-layer) layers are defined in the glossary.
## Why are there multiple clients? {#why-multiple-clients}
@@ -31,11 +30,11 @@ Client diversity also offers resilience to attacks. For example, an attack that
### Proof-of-stake finality {#finality}
-Ethereum has had 100% uptime since the network began. After The Merge, the risks caused by poor client diversity become more alarming. A critical bug in a consensus client with over 33% of the Ethereum nodes could prevent the Beacon Chain from finalizing, causing Ethereum to go offline.
+A bug in a consensus client with over 33% of the Ethereum nodes could prevent the Beacon Chain from finalizing, meaning users could not trust that transactions would not be reverted or changed at some point. This would be very problematic for many of the apps built on top of Ethereum, particularly DeFi.
Worse still, a critical bug in a client with a two-thirds majority could cause the chain to incorrectly split and finalize, leading to a large set of validators getting stuck on an invalid chain. If they want to rejoin the correct chain, these validators face slashing or a slow and expensive voluntary withdrawal and reactivation. The magnitude of a slashing scales with the number of culpable nodes with a two-thirds majority slashed maximally (32 ETH).
-Although these are unlikely scenarios, the Ethereum eco-system can mitigate their risk by evening out the distribution of clients across the active nodes. Ideally, no consensus client would ever have more than a 33% share of the total nodes.
+Although these are unlikely scenarios, the Ethereum eco-system can mitigate their risk by evening out the distribution of clients across the active nodes. Ideally, no consensus client would ever reach a 33% share of the total nodes.
### Shared responsibility {#responsibility}
diff --git a/src/content/developers/docs/nodes-and-clients/index.md b/src/content/developers/docs/nodes-and-clients/index.md
index 2e0db0550f3..2adbb193c71 100644
--- a/src/content/developers/docs/nodes-and-clients/index.md
+++ b/src/content/developers/docs/nodes-and-clients/index.md
@@ -4,7 +4,6 @@ description: An overview of Ethereum nodes and client software, plus how to set
lang: en
sidebar: true
sidebarDepth: 2
-preMergeBanner: true
---
Ethereum is a distributed network of computers (known as nodes) running software that can verify blocks and transaction data. The software application, known as a client, must be run on your computer to turn it into an Ethereum node.
diff --git a/src/content/developers/docs/nodes-and-clients/nodes-as-a-service/index.md b/src/content/developers/docs/nodes-and-clients/nodes-as-a-service/index.md
index eadf1f69cca..6eaf764fb86 100644
--- a/src/content/developers/docs/nodes-and-clients/nodes-as-a-service/index.md
+++ b/src/content/developers/docs/nodes-and-clients/nodes-as-a-service/index.md
@@ -4,19 +4,24 @@ description: An entry-level overview of node services, the pros and cons, and po
lang: en
sidebar: true
sidebarDepth: 2
-preMergeBanner: true
---
## Introduction {#Introduction}
Running your own [Ethereum node](/developers/docs/nodes-and-clients/#what-are-nodes-and-clients) can be challenging, especially when getting started or while scaling fast. There are a [number of services](#popular-node-services) that run optimized node infrastructures for you, so you can focus on developing your application or product instead. We'll explain how node services work, the pros and cons for using them and list providers if you are interested in getting started.
-**Note: it has been common for users to run consensus clients locally and use a node-as-a-service provider in place of a local execution client. This will not be possible at The Merge - users will be required to run BOTH clients locally. Users relying on node-as-a-service providers for their consensus clients will not merge correctly and will not be able to follow the Ethereum chain. Now is the time to install a local execution client!**
-
## Prerequisites {#prerequisites}
If you don't already have an understanding of what nodes and clients are, check out [Nodes and clients](/developers/docs/nodes-and-clients/).
+## Stakers {#stakoooooooooooooors}
+
+Solo stakers must run their own infrastructure rather than relying on third-party providers. This means running an execution client coupled with a consensus client. Before [The Merge](/upgrades/merge), it was possible to run a consensus client only and use a centralized provider for execution data; this is no longer possible - a solo staker must run both clients. However, there are services available to ease this process.
+
+[Read more on running a node](/developers/docs/nodes-and-clients/run-a-node/).
+
+The services described on this page are for non-staking nodes.
+
## How do node services work? {#how-do-node-services-work}
Node service providers run distributed node clients behind the scenes for you, so you don't have to.
diff --git a/src/content/developers/docs/nodes-and-clients/run-a-node/index.md b/src/content/developers/docs/nodes-and-clients/run-a-node/index.md
index 34f58d5e588..72bb3d9075b 100644
--- a/src/content/developers/docs/nodes-and-clients/run-a-node/index.md
+++ b/src/content/developers/docs/nodes-and-clients/run-a-node/index.md
@@ -4,7 +4,6 @@ description: General introduction to running your own instance of an Ethereum cl
lang: en
sidebar: true
sidebarDepth: 2
-preMergeBanner: true
---
Running your own node provides you various benefits, opens new possibilities, and helps to support the ecosystem. This page will guide you through spinning up your own node and taking part in validating Ethereum transactions.
diff --git a/src/content/developers/docs/storage/index.md b/src/content/developers/docs/storage/index.md
index bd03af39154..5429b93dac9 100644
--- a/src/content/developers/docs/storage/index.md
+++ b/src/content/developers/docs/storage/index.md
@@ -28,7 +28,7 @@ This is known as **blockchain-based** persistence.
The issue with blockchain-based persistence is that the chain could get far too big to upkeep and store all the data feasibly (e.g. [many sources](https://healthit.com.au/how-big-is-the-internet-and-how-do-we-measure-it/) estimate the Internet to require over 40 Zetabytes of storage capacity).
-The blockchain must also have some type of incentive structure. For blockchain-based persistence, there is a payment made to the miner. When the data is added to the chain, the nodes are paid to add the data on.
+The blockchain must also have some type of incentive structure. For blockchain-based persistence, there is a payment made to the validator. When the data is added to the chain, the validators are paid to add the data on.
Platforms with blockchain-based persistence:
@@ -89,15 +89,14 @@ Decentralized tools without KYC:
Most of these tools have their own version of a [consensus mechanism](/developers/docs/consensus-mechanisms/) but generally they are based on either [**proof-of-work (PoW)**](/developers/docs/consensus-mechanisms/pow/) or [**proof-of-stake (PoS)**](/developers/docs/consensus-mechanisms/pos/).
-PoW based:
+Proof-of-work based:
- Skynet
- Arweave
-- Ethereum
-PoS based:
+Proof-of-stake based:
-- [The Beacon Chain](/upgrades/beacon-chain/)
+- Ethereum
- Filecoin
- 0Chain
diff --git a/src/content/developers/docs/transactions/index.md b/src/content/developers/docs/transactions/index.md
index 3bdc664e8bd..20eab4767d9 100644
--- a/src/content/developers/docs/transactions/index.md
+++ b/src/content/developers/docs/transactions/index.md
@@ -3,7 +3,6 @@ title: Transactions
description: An overview of Ethereum transactions – how they work, their data structure, and how to send them via an application.
lang: en
sidebar: true
-preMergeBanner: true
---
Transactions are cryptographically signed instructions from accounts. An account will initiate a transaction to update the state of the Ethereum network. The simplest transaction is transferring ETH from one account to another.
@@ -19,9 +18,9 @@ An Ethereum transaction refers to an action initiated by an externally-owned acc
![Diagram showing a transaction cause state change](./tx.png)
_Diagram adapted from [Ethereum EVM illustrated](https://takenobu-hs.github.io/downloads/ethereum_evm_illustrated.pdf)_
-Transactions, which change the state of the EVM, need to be broadcast to the whole network. Any node can broadcast a request for a transaction to be executed on the EVM; after this happens, a miner will execute the transaction and propagate the resulting state change to the rest of the network.
+Transactions, which change the state of the EVM, need to be broadcast to the whole network. Any node can broadcast a request for a transaction to be executed on the EVM; after this happens, a validator will execute the transaction and propagate the resulting state change to the rest of the network.
-Transactions require a fee and must be mined to become valid. To make this overview simpler we'll cover gas fees and mining elsewhere.
+Transactions require a fee and must be included in a validated block. To make this overview simpler we'll cover gas fees and validation elsewhere.
A submitted transaction includes the following information:
@@ -31,10 +30,10 @@ A submitted transaction includes the following information:
- `value` – amount of ETH to transfer from sender to recipient (in WEI, a denomination of ETH)
- `data` – optional field to include arbitrary data
- `gasLimit` – the maximum amount of gas units that can be consumed by the transaction. Units of gas represent computational steps
-- `maxPriorityFeePerGas` - the maximum amount of gas to be included as a tip to the miner
+- `maxPriorityFeePerGas` - the maximum amount of gas to be included as a tip to the validator
- `maxFeePerGas` - the maximum amount of gas willing to be paid for the transaction (inclusive of `baseFeePerGas` and `maxPriorityFeePerGas`)
-Gas is a reference to the computation required to process the transaction by a miner. Users have to pay a fee for this computation. The `gasLimit`, and `maxPriorityFeePerGas` determine the maximum transaction fee paid to the miner. [More on Gas](/developers/docs/gas/).
+Gas is a reference to the computation required to process the transaction by a validator. Users have to pay a fee for this computation. The `gasLimit`, and `maxPriorityFeePerGas` determine the maximum transaction fee paid to the validator. [More on Gas](/developers/docs/gas/).
The transaction object will look a little like this:
@@ -159,7 +158,7 @@ Alice's account will be credited **+1.0 ETH**
The base fee will be burned **-0.00399 ETH**
-Miner keeps the tip **+0.000210 ETH**
+Validator keeps the tip **+0.000210 ETH**
Gas is required for any smart contract interaction too.
@@ -175,11 +174,10 @@ Once the transaction has been submitted the following happens:
1. Once you send a transaction, cryptography generates a transaction hash:
`0x97d99bc7729211111a21b12c933c949d4f31684f1d6954ff477d0477538ff017`
2. The transaction is then broadcast to the network and included in a pool with lots of other transactions.
-3. A miner must pick your transaction and include it in a block in order to verify the transaction and consider it "successful".
- - You may end up waiting at this stage if the network is busy and miners aren't able to keep up.
-4. Your transaction will receive "confirmations". The number of confirmations is the number of blocks created since the block that included your transaction. The higher the number, the greater the certainty that the network processed and recognized the transaction.
- - Recent blocks may get re-organized, giving the impression the transaction was unsuccessful; however, the transaction may still be valid but included in a different block.
- - The probability of a re-organization diminishes with every subsequent block mined, i.e. the greater the number of confirmations, the more immutable the transaction is.
+3. A validator must pick your transaction and include it in a block in order to verify the transaction and consider it "successful".
+4. As time passes the block containing your transaction will be upgraded to "justified" then "finalized". These upgrades make it much
+ more certain that your transaction was successful and will never be altered. Once a block is "finalized" it could only ever be changed
+ by an attack that would cost many billions of dollars.
## A visual demo {#a-visual-demo}
@@ -217,4 +215,3 @@ _Know of a community resource that helped you? Edit this page and add it!_
- [Accounts](/developers/docs/accounts/)
- [Ethereum virtual machine (EVM)](/developers/docs/evm/)
- [Gas](/developers/docs/gas/)
-- [Mining](/developers/docs/consensus-mechanisms/pow/mining/)
diff --git a/src/content/developers/docs/web2-vs-web3/index.md b/src/content/developers/docs/web2-vs-web3/index.md
index 9e8fd683ad9..8bf58912ccb 100644
--- a/src/content/developers/docs/web2-vs-web3/index.md
+++ b/src/content/developers/docs/web2-vs-web3/index.md
@@ -32,7 +32,7 @@ This doesn't mean that all services need to be turned into a dapp. These example
Web3 has some limitations right now:
-- Scalability – transactions are slower on web3 because they're decentralized. Changes to state, like a payment, need to be processed by a miner and propagated throughout the network.
+- Scalability – transactions are slower on web3 because they're decentralized. Changes to state, like a payment, need to be processed by a node and propagated throughout the network.
- UX – interacting with web3 applications can require extra steps, software, and education. This can be a hurdle to adoption.
- Accessibility – the lack of integration in modern web browsers makes web3 less accessible to most users.
- Cost – most successful dapps put very small portions of their code on the blockchain as it's expensive.
diff --git a/src/content/developers/tutorials/a-developers-guide-to-ethereum-part-one/index.md b/src/content/developers/tutorials/a-developers-guide-to-ethereum-part-one/index.md
index 969e69dc971..6e70d0f12b7 100644
--- a/src/content/developers/tutorials/a-developers-guide-to-ethereum-part-one/index.md
+++ b/src/content/developers/tutorials/a-developers-guide-to-ethereum-part-one/index.md
@@ -34,7 +34,6 @@ There are many ways to describe Ethereum, but at its heart is a blockchain. Bloc
"number": 1234567,
"hash": "0xabc123...",
"parentHash": "0xdef456...",
- "miner": "0xa1b2c3...",
...,
"transactions": [...]
}
@@ -58,7 +57,7 @@ This new decentralized tech stack has spawned new developer tools. Such tools ex
Python developers that want to interact with Ethereum are likely to reach for [Web3.py](https://web3py.readthedocs.io/). Web3.py is a library that greatly simplifies the way you connect to an Ethereum node, then send and receive data from it.
-
Note: “Ethereum node” and “Ethereum client” are used interchangeably. In either case, it refers to the software that a participant in the Ethereum network runs. This software can read block data, receive updates when new blocks are added to the chain ("mined"), broadcast new transactions, and more.
+
Note: “Ethereum node” and “Ethereum client” are used interchangeably. In either case, it refers to the software that a participant in the Ethereum network runs. This software can read block data, receive updates when new blocks are added to the chain, broadcast new transactions, and more. Technically, the client is the software, the node is the computer running the software.
[Ethereum clients](/developers/docs/nodes-and-clients/) can be configured to be reachable by [IPC](https://wikipedia.org/wiki/Inter-process_communication), HTTP, or Websockets, so Web3.py will need to mirror this configuration. Web3.py refers to these connection options as **providers**. You’ll want to choose one of the three providers to link the Web3.py instance with your node.
@@ -236,13 +235,13 @@ Out[9]: AttributeDict({
A lot of information gets returned about a block, but just a couple things to point out here:
-- The block number is zero — no matter how long ago you configured the tester provider. Unlike the real Ethereum network, which mines a new block roughly every 15 seconds, this simulation will wait until you give it some work to do.
+- The block number is zero — no matter how long ago you configured the tester provider. Unlike the real Ethereum network, which adds a new block every 12 seconds, this simulation will wait until you give it some work to do.
- `transactions` is an empty list, for the same reason: we haven’t done anything yet. This first block is an **empty block**, just to kick off the chain.
- Notice that the `parentHash` is just a bunch of empty bytes. This signifies that it's the first block in the chain, also known as the **genesis block**.
## Tour stop #3: [transactions](/developers/docs/transactions/) {#tour-stop-3-transactions}
-We’re stuck at block zero until there’s a transaction to mine, so let’s give it one. Send a few test ether from one account to another:
+We’re stuck at block zero until there’s a pending transaction, so let’s give it one. Send a few test ether from one account to another:
```python
In [10]: tx_hash = w3.eth.send_transaction({
@@ -253,11 +252,11 @@ In [10]: tx_hash = w3.eth.send_transaction({
})
```
-This is typically the point where you’d wait for several seconds for your transaction to get mined into a new block. The full process goes something like this:
+This is typically the point where you’d wait for several seconds for your transaction to get included in a new block. The full process goes something like this:
-1. Submit a transaction and hold on to the transaction hash. Until it gets mined, the transaction is “pending.”
+1. Submit a transaction and hold on to the transaction hash. Until the block containing the transaction is created and broadcast, the transaction is “pending.”
`tx_hash = w3.eth.send_transaction({ … })`
-2. Wait for the transaction to be mined:
+2. Wait for the transaction to be included in a block:
`w3.eth.wait_for_transaction_receipt(tx_hash)`
3. Continue application logic. To view the successful transaction:
`w3.eth.get_transaction(tx_hash)`
diff --git a/src/content/developers/tutorials/downsizing-contracts-to-fight-the-contract-size-limit/index.md b/src/content/developers/tutorials/downsizing-contracts-to-fight-the-contract-size-limit/index.md
index 0e477e12fc2..f01a88ce4a1 100644
--- a/src/content/developers/tutorials/downsizing-contracts-to-fight-the-contract-size-limit/index.md
+++ b/src/content/developers/tutorials/downsizing-contracts-to-fight-the-contract-size-limit/index.md
@@ -19,7 +19,7 @@ On [November 22, 2016](https://blog.ethereum.org/2016/11/18/hard-fork-no-4-spuri
This limit was introduced to prevent denial-of-service (DOS) attacks. Any call to a contract is relatively cheap gas-wise. However, the impact of a contract call for Ethereum nodes increases disproportionately depending on the called contract code's size (reading the code from disk, pre-processing the code, adding data to the Merkle proof). Whenever you have such a situation where the attacker requires few resources to cause a lot of work for others, you get the potential for DOS attacks.
-Originally this was less of a problem, because one natural contract size limit is the block gas limit. Obviously a contract needs to be deployed within a transaction that holds all of the contract's bytecode. If you then include only that one transaction into a block, you can use up all of that gas, but it's not infinite. The issue in that case though is that the block gas limit changes over time and is in theory unbounded. At the time of the EIP-170 the block gas limit was only 4.7 million. Now the block gas limit just [increased again](https://etherscan.io/chart/gaslimit) last month to 11.9 million.
+Originally this was less of a problem because one natural contract size limit is the block gas limit. Obviously, a contract must be deployed within a transaction that holds all of the contract's bytecode. If you include only that one transaction into a block, you can use up all that gas, but it's not infinite. Since the [London Upgrade](/history/#london), the block gas limit has been able to vary between 15M and 30M units depending on network demand.
## Taking on the fight {#taking-on-the-fight}
@@ -146,9 +146,3 @@ function doSomething() { checkStuff(); }
```
Those tips should help you to significantly reduce the contract size. Once again, I cannot stress enough, always focus on splitting contracts if possible for the biggest impact.
-
-## The future for the contract size limits {#the-future-for-the-contract-size-limits}
-
-There is an [open proposal](https://github.com/ethereum/EIPs/issues/1662) to remove the contract size limit. The idea is basically to make contract calls more expensive for large contracts. It wouldn't be too difficult to implement, has a simple backwards compatibility (put all previously deployed contracts in the cheapest category), but [not everyone is convinced](https://ethereum-magicians.org/t/removing-or-increasing-the-contract-size-limit/3045/24).
-
-Only time will tell if those limits will change in the future, the reactions (see image on the right) definitely show a clear requirement for us developers. Unfortunately, it is not something you can expect any time soon.
diff --git a/src/content/developers/tutorials/hello-world-smart-contract-fullstack/index.md b/src/content/developers/tutorials/hello-world-smart-contract-fullstack/index.md
index 9d6786ff9a7..d59d04e4feb 100644
--- a/src/content/developers/tutorials/hello-world-smart-contract-fullstack/index.md
+++ b/src/content/developers/tutorials/hello-world-smart-contract-fullstack/index.md
@@ -20,6 +20,7 @@ skill: beginner
lang: en
sidebar: true
published: 2021-10-25
+postMergeBannerTranslation: page-upgrades-post-merge-banner-tutorial-ood
---
This guide is for you if you are new to blockchain development and don't know where to start or how to deploy and interact with smart contracts. We will walk through creating and deploying a simple, smart contract on the Ropsten test network using [MetaMask](https://metamask.io), [Solidity](https://docs.soliditylang.org/en/v0.8.0/), [Hardhat](https://hardhat.org), and [Alchemy](https://alchemyapi.io/eth).
diff --git a/src/content/developers/tutorials/learn-foundational-ethereum-topics-with-sql/index.md b/src/content/developers/tutorials/learn-foundational-ethereum-topics-with-sql/index.md
index 6bc24ff3ad0..690c73852e4 100644
--- a/src/content/developers/tutorials/learn-foundational-ethereum-topics-with-sql/index.md
+++ b/src/content/developers/tutorials/learn-foundational-ethereum-topics-with-sql/index.md
@@ -73,13 +73,13 @@ This will yield the same information as provided on Etherscan's transaction page
#### Etherscan {#etherscan}
-![etherscan_view](./etherscan_view.png)
+![](./etherscan_view.png)
[EF's contract page on Etherscan.](https://etherscan.io/address/0xde0B295669a9FD93d5F28D9Ec85E40f4cb697BAe)
#### Dune Analytics {#dune-analytics}
-![dune_view](./dune_view.png)
+![](./dune_view.png)
You can find dashboard [here](https://duneanalytics.com/paulapivat/Learn-Ethereum). Click on the table to see the query (also see above).
@@ -91,8 +91,9 @@ A submitted transaction includes several pieces of information including ([sourc
- **Signature**: While a sender's private keys signs a transaction, what we can query with SQL is a sender's public address ("from").
- **Value**: This is the amount of ETH transferred (see `ether` column).
- **Data**: This is arbitrary data that's been hashed (see `data` column)
-- **gasLimit**: The maximum amount of gas, or the cost of computation, that can be consumed by a transaction (see `gas_limit`).
-- **gasPrice**: The fee the sender pays to sign a transaction to the blockchain. Gas is denominated in Gwei which is 0.000000001 ETH (nine decimal places).
+- **gasLimit** – the maximum amount of gas units that can be consumed by the transaction. Units of gas represent computational steps
+- **maxPriorityFeePerGas** - the maximum amount of gas to be included as a tip to the miner
+- **maxFeePerGas** - the maximum amount of gas willing to be paid for the transaction (inclusive of baseFeePerGas and maxPriorityFeePerGas)
We can query these specific pieces of information for transactions to the Ethereum Foundation public address:
@@ -127,7 +128,6 @@ Here is the [query](https://duneanalytics.com/queries/44856/88292) on Dune Analy
SELECT
time,
number,
- difficulty,
hash,
parent_hash,
nonce
@@ -157,7 +157,7 @@ ORDER BY block_time DESC`
Here's the SQL output on Dune:
-![list_of_txn](./list_of_txn.png)
+![](./list_of_txn.png)
This single block being added to the chain changes the state of the Ethereum virtual machine ([EVM](/developers/docs/evm/)). Dozens sometimes, hundreds of transactions are verified at once. In this specific case, 222 transactions were included.
@@ -176,19 +176,19 @@ FROM temp_table
For block 12396854, out of 222 total transactions, 204 were successfully verified:
-![successful_txn](./successful_txn.png)
+![](./successful_txn.png)
Transactions requests occur dozens of times per second, but blocks are committed approximately once every 15 seconds ([source](/developers/docs/blocks/)).
-To see that there is one block produced approximately every 15 seconds, we could take the number of seconds in a day (86400) divided by 15 to get an _estimate_ average number of blocks per day (~ 5760).
+To see that there is one block produced approximately every 15 seconds, we could take the number of seconds in a day (86400) divided by 15 to get an estimated average number of blocks per day (~ 5760).
The chart for Ethereum blocks produced per day (2016 - present) is:
-![daily_blocks](./daily_blocks.png)
+![](./daily_blocks.png)
The average number of blocks produced daily over this time period is ~5,874:
-![avg_daily_blocks](./avg_daily_blocks.png)
+![](./avg_daily_blocks.png)
The queries are:
@@ -221,11 +221,11 @@ The average number of blocks produced per day since 2016 is slightly above that
### Gas {#gas}
-Blocks are bounded in size. Each block has a gas limit which is collectively set by miners and the network to prevent arbitrarily large block size to be less of a strain on full node in terms of disk space and speed requirements ([source](/developers/docs/blocks/)).
+Blocks are bounded in size. The maximum block size is dynamic and varies according to network demand between 12,500,000 and 25,000,000 units. Limits are required to prevent arbitrarily large block sizes putting strain on full nodes in terms of disk space and speed requirements ([source](/developers/docs/blocks/)).
One way to conceptualize block gas limit is to think of it as the **supply** of available block space in which to batch transactions. The block gas limit can be queried and visualized from 2016 to present day:
-![avg_gas_limit](./avg_gas_limit.png)
+![](./avg_gas_limit.png)
```sql
SELECT
@@ -238,7 +238,7 @@ OFFSET 1
Then there is the actual gas used daily to pay for computing done on the Ethereum chain (i.e., sending transaction, calling a smart contract, minting an NFT). This is the **demand** for available Ethereum block space:
-![daily_gas_used](./daily_gas_used.png)
+![](./daily_gas_used.png)
```sql
SELECT
@@ -257,9 +257,9 @@ Therefore we can understand gas prices as a function of demand for Ethereum bloc
Finally, we may want to query average daily gas prices for the Ethereum chain, however, doing so will result in an especially long query time, so we’ll filter our query to the average amount of gas paid per transaction by the Ethereum Foundation.
-![ef_daily_gas](./ef_daily_gas.png)
+![](./ef_daily_gas.png)
-We can see gas prices paid in transaction to the Ethereum Foundation address over the years. Here is the query:
+We can see gas prices paid for all transactions made to the Ethereum Foundation address over the years. Here is the query:
```sql
SELECT
diff --git a/src/content/developers/tutorials/run-light-node-geth/index.md b/src/content/developers/tutorials/run-light-node-geth/index.md
index 6f398363d8e..10c71042675 100644
--- a/src/content/developers/tutorials/run-light-node-geth/index.md
+++ b/src/content/developers/tutorials/run-light-node-geth/index.md
@@ -7,7 +7,7 @@ skill: beginner
lang: en
sidebar: true
published: 2022-03-04
-preMergeBanner: true
+postMergeBannerTranslation: page-upgrades-post-merge-banner-tutorial-light-node-ood
---
**Please note that Geth light clients can be very slow to find peers. This is because they rely on full-node operators volunteering themselves as light servers from which the light clients can request data. There are usually only a small number of light servers available.**
diff --git a/src/content/developers/tutorials/run-node-raspberry-pi/index.md b/src/content/developers/tutorials/run-node-raspberry-pi/index.md
index f66e06dc6b9..3cdd220323c 100644
--- a/src/content/developers/tutorials/run-node-raspberry-pi/index.md
+++ b/src/content/developers/tutorials/run-node-raspberry-pi/index.md
@@ -9,7 +9,7 @@ skill: intermediate
published: 2022-06-10
source: Ethereum on ARM
sourceUrl: https://ethereum-on-arm-documentation.readthedocs.io/en/latest/kiln/kiln-testnet.html
-preMergeBanner: true
+postMergeBannerTranslation: page-upgrades-post-merge-banner-tutorial-ood
---
**Ethereum on Arm is a custom Linux image that can turn a Raspberry Pi into an Ethereum node.**
diff --git a/src/content/developers/tutorials/uniswap-v2-annotated-code/index.md b/src/content/developers/tutorials/uniswap-v2-annotated-code/index.md
index 18207784694..e69f9f5d55f 100644
--- a/src/content/developers/tutorials/uniswap-v2-annotated-code/index.md
+++ b/src/content/developers/tutorials/uniswap-v2-annotated-code/index.md
@@ -27,12 +27,11 @@ When liquidity providers want their assets back they can burn the pool tokens an
### Why v2? Why not v3? {#why-v2}
-As I'm writing this, [Uniswap v3](https://uniswap.org/whitepaper-v3.pdf) is almost ready. However, it is an upgrade that is much more complicated than the original. It is easier to first learn v2 and then go to v3.
+[Uniswap v3](https://uniswap.org/whitepaper-v3.pdf) is an upgrade that is much more complicated than the v2. It is easier to first learn v2 and then go to v3.
### Core Contracts vs Periphery Contracts {#contract-types}
-Uniswap v2 is divided into two components, a core and a periphery. This division allows the core contracts, which hold the assets and therefore _have_ to be secure, to be simpler and easier to audit.
-All the extra functionality required by traders can then be provided by periphery contracts.
+Uniswap v2 is divided into two components, a core and a periphery. This division allows the core contracts, which hold the assets and therefore _have_ to be secure, to be simpler and easier to audit. All the extra functionality required by traders can then be provided by periphery contracts.
## Data and Control Flows {#flows}
@@ -1011,7 +1010,7 @@ For example, imagine a case where the exchange rate is one to one and the liquid
As long as the exchange rate stays between 0.9 and 1.25, the transaction takes place. If the exchange rate gets out of that range, the transaction gets cancelled.
-The reason for this precaution is that transactions are not immediate, you submit them and eventually a miner is going to include them in a block (unless your gas price is very low, in which case you'll need to submit another transaction with the same nonce and a higher gas price to overwrite it). You cannot control what happens during the interval between submission and inclusion.
+The reason for this precaution is that transactions are not immediate, you submit them and eventually a validator is going to include them in a block (unless your gas price is very low, in which case you'll need to submit another transaction with the same nonce and a higher gas price to overwrite it). You cannot control what happens during the interval between submission and inclusion.
```solidity
) internal virtual returns (uint amountA, uint amountB) {
diff --git a/src/content/developers/tutorials/using-websockets/index.md b/src/content/developers/tutorials/using-websockets/index.md
index d89597f69c2..0d046f47ed6 100644
--- a/src/content/developers/tutorials/using-websockets/index.md
+++ b/src/content/developers/tutorials/using-websockets/index.md
@@ -145,13 +145,11 @@ Example:
"method": "eth_subscription",
"params": {
"result": {
- "difficulty": "0x15d9223a23aa",
"extraData": "0xd983010305844765746887676f312e342e328777696e646f7773",
"gasLimit": "0x47e7c4",
"gasUsed": "0x38658",
"logsBloom":
"0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000",
- "miner": "0xf8b483dba2c3b7176a3da549ad41a48bb3121069",
"nonce": "0x084149998194cc5f",
"number": "0x1348c9",
"parentHash": "0x7736fab79e05dc611604d22470dadad26f56fe494421b5b333de816ce1f25701",
diff --git a/src/content/energy-consumption/index.md b/src/content/energy-consumption/index.md
index 3a1aab48037..3805e40e514 100644
--- a/src/content/energy-consumption/index.md
+++ b/src/content/energy-consumption/index.md
@@ -7,50 +7,50 @@ sidebar: true
# Ethereum energy consumption {#introduction}
-Ethereum's energy consumption will be reduced by ~99.95% following [The Merge](/upgrades/merge) from proof-of-work (PoW) to proof-of-stake (PoS). After The Merge, Ethereum will use dramatically less carbon to be more secure.
+Ethereum is a green blockchain. It uses a [proof-of-stake](/developers/docs/consensus-mechanisms/pos) consensus mechanism that can be run on low-powered devices and does not require heavy computation to participate. Ethereum's proof-of-stake mechanism secures the network by using staked ETH rather than expended energy, like in [proof-of-work](/developers/docs/consensus-mechanisms/pos). The switch to proof-of-stake means the energy expended by the Ethereum network is relatively small - on the order of 0.01 TWh/yr.
-Since its inception, Ethereum has aimed to implement a proof-of-stake consensus mechanism, but doing this without compromising [Ethereum's vision of being a secure, scalable, and decentralized blockchain](/upgrades/vision/) has taken years of focused research and development. Therefore, the network started by using proof-of-work consensus. Proof-of-work consensus requires miners to use their computing hardware to solve a puzzle. The solution to the puzzle proves that energy has been expended by the miner, demonstrating that they invested real-world value for the right to add to the blockchain. Both proof-of-work and proof-of-stake are just mechanisms to decide who gets to add the next block. Swapping proof-of-work for proof-of-stake, where the real-world value invested comes from ETH staked directly in a smart contract, removes the need for miners to burn energy to add to the blockchain. Therefore, the environmental cost of securing the network is drastically reduced.
+## Proof-of-stake energy expenditure {#proof-of-stake-energy}
-## The Merge {#the-merge}
+The energy expenditure of Ethereum is roughly equal to the cost of running a modest laptop for each node on the network.
-[The Beacon Chain](/upgrades/beacon-chain/) has been running the proof-of-stake since November 2020 alongside the proof-of-work Ethereum Mainnet. In 2022, Ethereum developers transitioned several **testing networks (testnets)** running proof-of-work to proof-of-stake by merging with their own Beacon Chains. These helped client teams test the software before moving to longer-lived networks. After these testnets, Ethereum developers launched new testnets for the community to use (Kiln & Kintsugi) and ran multiple shadow forks of existing testnets and Mainnet. Now that these have stabilized, teams are moving to the final stages of testing: transitioning long-lived testnets (Ropsten, Goerli, Sepolia) to proof-of-stake. Merging Ethereum Mainnet with the Beacon Chain is expected to happen in the second half of 2022. At the moment of the merge, Ethereum's proof-of-work mining will be switched off, proof-of-stake consensus will take over, and the energy consumed by the network will drop to <0.05% of its pre-merge amount.
+Many articles estimate "per-transaction" energy expenditure to compare blockchains to other industries. The benefit of this is that it is easy to understand. However, transaction-based estimates can be misleading because the energy required to propose and validate a block is independent of the number of transactions within it. A per transaction unit of energy expenditure implies that fewer transactions would lead to smaller energy expenditure and vice-versa, which is not the case. A per-transaction estimate is highly dependent upon how a blockchain's transaction throughput is defined, and tweaking this definition can be gamed to make the value seem larger or smaller.
-## Why proof-of-stake is greener than proof-of-work {#why-pos-is-greener-than-pow}
+For example, on Ethereum, the transaction throughput is not only that of the base layer - it is also the sum of the transaction throughput of all of its "[layer 2](/layer-2/)" rollups, which are not generally included in calculations and would drastically reduce them. This is one reason why tools that compare energy consumption per transaction across platforms are misleading.
-Proof-of-work is a robust way to secure the network. Transactions on the Ethereum blockchain are validated by [miners](/developers/docs/consensus-mechanisms/pow/mining). Miners bundle together transactions into ordered blocks and add them to the Ethereum blockchain. The new blocks get broadcast to all the other node operators who run the transactions independently and verify that they are valid. Any dishonesty shows up as an inconsistency between different nodes. Honest blocks are added to the blockchain and become an immutable part of history.
-The ability for any miner to add new blocks only works if there is a cost associated with mining and unpredictability about which specific node submits the next block. These conditions are met by imposing proof-of-work. To be eligible to submit a block of transactions, a miner must be the first to submit the solution to a computationally expensive puzzle. To successfully take control of the blockchain, a dishonest miner would have to consistently win the proof-of-work race by investing in sufficient hardware and energy to outperform the majority of other miners.
+More relevant is the overall energy consumption and carbon footprint of the network as a whole. From those values, we can examine what that network offers to its users and society at large and make a more holistic evaluation of whether that energy expenditure is justified or not. Per transaction measurements, on the other hand, imply the value of the network only comes from its role in transferring crypto between accounts and prohibits an honest cost-benefit analysis.
-This mechanism of securing the network is problematic for several reasons. First, miners can increase their odds of success by investing in more powerful hardware, creating conditions for an arms race with miners acquiring increasingly power-hungry mining equipment. This increases the network's energy consumption and generates hardware waste. Second, Ethereum's proof-of-work protocol currently has a total annualized power consumption approximately equal to that of Finland [^1] and a carbon footprint similar to Switzerland[^1].
+[Digiconomist provides whole-network energy consumption and carbon footprints for Bitcoin and Ethereum](https://digiconomist.net/ethereum-energy-consumption). At the time of writing this article, Bitcoin expends about 200 TWh/yr of energy and emits about 100 MT (megatons) of carbon per year, while generating about 32,000 T of electrical waste from obsolete hardware annually. In comparison, the total energy expenditure for securing Ethereum is closer to **0.01 TWh/yr**.
-Proof-of-stake uses validators instead of miners. Validators perform the same function as miners, except that instead of expending their assets up-front as energy expenditure, they stake ETH as collateral against dishonest behavior. This staked ETH can be destroyed if the validator misbehaves, with more severe penalties for more nefarious actions. This strongly incentivizes active and honest participation in securing the network without requiring large energy expenditure. Since almost all of the energy expended securing the proof-of-work network comes from the mining algorithm, switching to proof-of-stake dramatically reduces energy expenditure. There is also no benefit to be had by investing in more powerful hardware under proof-of-stake, so there is no arms-race condition and less electronic waste. Ethereum validators can run on typical laptops or low-power devices such as [Raspberry Pi](https://ethereum-on-arm-documentation.readthedocs.io/en/latest/).
+
-Read more on [how Ethereum implements proof-of-stake](/developers/docs/consensus-mechanisms/pos) and how it compares to proof-of-work.
+The figure above shows the estimated annual energy consumption in TWh/yr for various industries (retrieved in June 2022).
+_Note that the estimates presented in the plot are from publicly available sources that have been linked to in the text below. They are
+illustrative and do not represent an official estimate, promise or forecast._
-## Proof-of-stake energy expenditure {#proof-of-stake-energy}
+To put Ethereum's energy consumption in context, we can compare annualized estimates for other industries. Taking Ethereum to be a platform for securely holding digital assets as investments, perhaps we can compare to mining gold, which has been estimated to expend about [240 TWh/yr](https://www.kitco.com/news/2021-05-17/Gold-s-energy-consumption-doubles-that-of-bitcoin-Galaxy-Digital.html). As a digital payments platform we could perhaps compare to PayPal (estimated to consume about [0.26 TWh/yr](https://app.impaakt.com/analyses/paypal-consumed-264100-mwh-of-energy-in-2020-24-from-non-renewable-sources-27261)). As an entertainment platform we could perhaps compare to the gaming industry which has been estimated to expend about [34 TW/yr](https://www.researchgate.net/publication/336909520_Toward_Greener_Gaming_Estimating_National_Energy_Use_and_Energy_Efficiency_Potential). Estimates of energy consumption by Netflix range dramatically between [about 0.45TWhr/yr](https://s22.q4cdn.com/959853165/files/doc_downloads/2020/02/0220_Netflix_EnvironmentalSocialGovernanceReport_FINAL.pdf) (their own estimates reported in 2019) up to about 94 TWh/yr (as estimated by [Shift Project](https://theshiftproject.org/en/article/unsustainable-use-online-video/)) - there is some discussion about the assumptions underlying these estimates available on [Carbon Brief](https://www.carbonbrief.org/factcheck-what-is-the-carbon-footprint-of-streaming-video-on-netflix). Alternatively, Ethereum could be compared to Youtube which has been estimated to expend about [244 TWh/yr](https://thefactsource.com/how-much-electricity-does-youtube-use/), although these values depend a lot on the type of device videos are streamed on and the energy-efficiency of underlying infrastructure such as data centers. Estimates of YouTube's energy expenditure have been broken down by channel and individual videos. [Those estimates](https://thefactsource.com/how-much-electricity-does-youtube-use/) imply that people consumed 45 times more energy watching Gangnam Style in 2019 than proof-of-stake Ethereum uses in a year.
-Estimates based on the current Beacon Chain suggest that The Merge to proof-of-stake could result in a 99.95% reduction in total energy use, with proof-of-stake being ~2000x more energy-efficient than proof-of-work. The energy expenditure of Ethereum will be roughly equal to the cost of running a modest laptop for each node on the network.
+## A green application layer {#green-applications}
-Many articles estimate "per-transaction" energy expenditure to compare blockchains to other industries. The benefit of this is that it is easy to understand, but the energy required to mine a block is independent of the number of transactions within it. A per transaction unit of energy expenditure implies that fewer transactions would lead to smaller energy expenditure and vice-versa, which is not the case. A per-transaction estimate is highly dependent upon how a blockchain's transaction throughput is defined, and tweaking this definition can be gamed to make the value seem larger or smaller.
+While Ethereum's energy consumption is very low, there is also a substantial, growing, and highly active **regenerative finance (ReFi)** community building on Ethereum. ReFi applications use DeFi components to build financial applications that have positive externalities benefiting the environment. ReFi is part of a wider ["solarpunk"](https://en.wikipedia.org/wiki/Solarpunk) movement that is closely aligned with Ethereum and aims to couple technological advancement and environmental stewardship. The decentralized, permissionless, composable nature of Ethereum makes it the ideal base layer for the ReFi and solarpunk communities. Through the development of these (and others, e.g. [DeSci](/desci/)), Ethereum is becoming an environmentally and socially-positive technology.
-For example, on Ethereum, the transaction throughput is not only that of the base layer - it is also the sum of the transaction throughput of all of its "[layer 2](/layer-2/)" rollups, which are not generally included in calculations and would drastically reduce them. This is why tools that compare energy consumption per transaction across platforms are misleading.
+## Ethereum's carbon debt {#carbon-debt}
-More relevant is the overall energy consumption and carbon footprint of the network as a whole. From those values, we can examine what that network offers to its users and society at large and make a more holistic evaluation of whether that energy expenditure is justified or not. Per transaction measurements, on the other hand, imply the value of the network only comes from its role in transferring crypto between accounts and prohibits an honest cost-benefit analysis.
+Ethereum's current energy expenditure is very low, but this has not always been the case. Ethereum switched on its proof-of-stake consensus mechanism in Q3 2022. However, Ethereum used a proof-of-work mechanism from 2014-2022, which had a much greater environmental cost.
-[Digiconomist provides whole-network energy consumption and carbon footprints for Bitcoin and Ethereum](https://digiconomist.net/ethereum-energy-consumption). At the time of writing this article, Ethereum's total energy consumption is ~112 TWh/yr, comparable to that of the Netherlands, with a Carbon emission equivalent to that of Singapore (53 MT/yr). For comparison, Bitcoin currently expends about 200 TWh/yr of energy and emits about 100 MT/yr C, while generating about 32,000 T of electrical waste from obsolete hardware annually. Switching off Ethereum's proof-of-work in favor of proof-of-stake will reduce this energy expenditure by more than 99.95%, implying that the total energy expenditure for securing Ethereum is closer to **0.01 TWh/yr**.
+Since its inception, Ethereum aimed to implement a proof-of-stake consensus mechanism, but doing so without sacrificing security and decentralization took years of focused research and development. Therefore, a proof-of-work mechanism was used to get the network started. Proof-of-work consensus requires miners to use their computing hardware to solve a puzzle, expending energy in the process. The solution to the puzzle proves that energy has been expended by the miner, demonstrating that they invested real-world value for the right to add to the blockchain. Ethereum's total energy consumption peaked during the apex of the crypto bull market in February 2022 at just under 94 TWh/yr. In the summer before the switch to proof-of-stake, the energy consumption was closer to 60 TWh/yr, comparable to that of Uzbekistan, with a carbon emission equivalent to that of Azerbaijan (33 MT/yr).
-![Comparison of energy expenditure across industries](./energy.png)
+Both proof-of-work and proof-of-stake are just mechanisms to decide who gets to add the next block. Swapping proof-of-work for proof-of-stake, where the real-world value invested comes from ETH staked directly in a smart contract, removes the need for miners to burn energy to add to the blockchain. Therefore, the environmental cost of securing the network is drastically reduced.
-The figure above shows the estimated annual energy consumption in TWh/yr for various industries (retrieved in June 2022).
-_Note that the estimates presented in the plot are from publicly available sources that have been linked to in the text below. They are
-illustrative and do not represent an official estimate, promise or forecast._
+## Why proof-of-stake is greener than proof-of-work {#why-pos-is-greener-than-pow}
-To put Ethereum's energy consumption in context, we can compare annualized estimates for other industries. If we take Ethereum to be a platform for securely holding digital assets as investments, perhaps we can compare to mining gold, which has been estimated to expend about [240 TWh/yr](https://www.kitco.com/news/2021-05-17/Gold-s-energy-consumption-doubles-that-of-bitcoin-Galaxy-Digital.html). As a digital payments platform we could perhaps compare to PayPal (estimated to consume about [0.26 TWh/yr](https://app.impaakt.com/analyses/paypal-consumed-264100-mwh-of-energy-in-2020-24-from-non-renewable-sources-27261)). As an entertainment platform we could perhaps compare to the gaming industry which has been estimated to expend about [34 TW/yr](https://www.researchgate.net/publication/336909520_Toward_Greener_Gaming_Estimating_National_Energy_Use_and_Energy_Efficiency_Potential). Estimates of energy consumption by Netflix range dramatically between [about 0.45TWhr/yr](https://s22.q4cdn.com/959853165/files/doc_downloads/2020/02/0220_Netflix_EnvironmentalSocialGovernanceReport_FINAL.pdf) (their own estimates reported in 2019) up to about 94 TWh/yr (as estimated by [Shift Project](https://theshiftproject.org/en/article/unsustainable-use-online-video/)) - there is some discussion about the assumptions underlying these estimates available on [Carbon Brief](https://www.carbonbrief.org/factcheck-what-is-the-carbon-footprint-of-streaming-video-on-netflix). Alternatively, Ethereum could be compared to Youtube which has been estimated to expend about [244 TWh/yr](https://thefactsource.com/how-much-electricity-does-youtube-use/), although these values depend a lot on the type of device videos are streamed on and the energy-efficiency of underlying infrastructure such as data centers. Estimates of Youtube's energy expenditure have been broken down by channel and individual videos. [Those estimates](https://thefactsource.com/how-much-electricity-does-youtube-use/) imply that people consumed 45 times more energy watching Gangnam Style in 2019 than proof-of-stake Ethereum will use in a year.
+Proof-of-work is a robust way to secure the network. Transactions on the Ethereum blockchain under the previous proof-of-work system were validated by [miners](/developers/docs/consensus-mechanisms/pow/mining). Miners bundled together transactions into ordered blocks and added them to the Ethereum blockchain. The new blocks got broadcast to all the other node operators who run the transactions independently and verify that they are valid. Any dishonesty showed up as an inconsistency between different nodes. Honest blocks were added to the blockchain and became an immutable part of history.
+The ability for any miner to add new blocks only works if there is a cost associated with mining and unpredictability about which specific node submits the next block. These conditions are met by imposing proof-of-work. To be eligible to submit a block of transactions, a miner must be the first to submit the solution to a computationally expensive puzzle. To successfully take control of the blockchain, a dishonest miner would have to consistently win the proof-of-work race by investing in sufficient hardware and energy to outperform the majority of other miners.
-## A greener Ethereum {#green-ethereum}
+This mechanism of securing the network is problematic for several reasons. First, miners would increase their odds of success by investing in more powerful hardware, creating conditions for an arms race with miners acquiring increasingly power-hungry mining equipment. This increased the network's energy consumption and generated hardware waste. Second, Ethereum's proof-of-work protocol (prior to transitioning to proof-of-stake) had a total annualized power consumption approximately equal to that of Finland [^1] and a carbon footprint similar to Switzerland[^1].
-While Ethereum's energy consumption has historically been substantial, there has been a significant investment of developer time and intellect into transitioning from energy-hungry to energy-efficient block production. To quote [Bankless](http://podcast.banklesshq.com/), the best way to reduce the energy consumed by proof-of-work is simply to "turn it off", which is the approach Ethereum has committed to taking.
+Proof-of-stake uses validators instead of miners. Validators perform the same function as miners, except that instead of expending their assets up-front as energy expenditure, they stake ETH as collateral against dishonest behavior. This staked ETH can be destroyed if the validator misbehaves, with more severe penalties for more nefarious actions. This strongly incentivizes active and honest participation in securing the network without requiring large energy expenditure. Since almost all of the energy expended securing the proof-of-work network came from the mining algorithm, the switch to proof-of-stake dramatically reduced energy expenditure. There is also no benefit to be had by investing in more powerful hardware under proof-of-stake, so there is no arms-race condition and less electronic waste. Ethereum validators can run on typical laptops or low-power devices such as a [Raspberry Pi](https://ethereum-on-arm-documentation.readthedocs.io/en/latest/user-guide/ethereum2.0.html).
-At the same time, there is a substantial, growing, and highly active **regenerative finance (ReFi)** community building on Ethereum. ReFi applications use DeFi components to build financial applications that have positive externalities benefiting the environment. ReFi is part of a wider "Solarpunk" movement that is closely aligned with Ethereum and aims to couple technological advancement and environmental stewardship. The decentralized, permissionless, composable nature of Ethereum makes it the ideal base layer for the ReFi and solarpunk communities. After The Merge, the technology and philosophy of Ethereum will finally reconcile, and Ethereum should become an environmentally-positive technology.
+Read more on [how Ethereum implements proof-of-stake](/developers/docs/consensus-mechanisms/pos) and how it compares to proof-of-work.
If you think these stats are incorrect or can be made more accurate, please raise an issue or PR. These are estimates by the ethereum.org team made using publicly accessible information and the current Ethereum roadmap. These statements don't represent an official promise from the Ethereum Foundation.
diff --git a/src/content/glossary/index.md b/src/content/glossary/index.md
index fdc3577919a..64f3f860e33 100644
--- a/src/content/glossary/index.md
+++ b/src/content/glossary/index.md
@@ -57,7 +57,7 @@ In [Solidity](#solidity), `assert(false)` compiles to `0xfe`, an invalid opcode,
### attestation {#attestation}
-A validator vote for a [Beacon Chain](#beacon-chain) or [shard](#shard) [block](#block). Validators must attest to blocks, signaling that they agree with the state proposed by the block.
+A claim made by an entity that something is true. In context of Ethereum, consensus validators must make a claim as to what they believe the state of the chain to be. At designated times, each validator is responsible for publishing different attestations that formally declare this validator's view of the chain, including the last finalized checkpoint and the current head of the chain.
Attestations
@@ -77,7 +77,7 @@ Every [block](#block) has a reserve price known as the 'base fee'. It is the min
### Beacon Chain {#beacon-chain}
-A network upgrade that introduced a new consensus layer, which will become the coordinator for the entire Ethereum network. It introduces [proof-of-stake](#pos) and [validators](#validator) to Ethereum. It will eventually be merged with [Mainnet](#mainnet).
+The Beacon Chain was the blockchain that introduced [proof-of-stake](#pos) and [validators](#validator) to Ethereum. It ran alongside the proof-of-work Ethereum Mainnet from December 2020 until the two chains were merged in September 2022 to form the Ethereum of today.
Beacon Chain
@@ -89,7 +89,7 @@ A positional number representation where the most significant digit is first in
### block {#block}
-A collection of required information (a block header) about the comprised [transactions](#transaction), and a set of other block headers known as [ommers](#ommer). Blocks are added to the Ethereum network by [miners](#miner).
+A block is a bundled unit of information that include an ordered list of transactions and consensus-related information. Blocks are proposed by proof-of-stake validators, at which point they are shared across the entire peer-to-peer network, where they can easily be independently verified by all other nodes. Consensus rules govern what contents of a block are considered valid, and any invalid blocks are disregarded by the network. The ordering of these blocks and the transactions therein create a deterministic chain of events with the end representing the current state of the network.
Blocks
@@ -101,30 +101,43 @@ An interface that allows a user to search for information from, and about, a blo
### block header {#block-header}
-The data in a block which is unique to its content and the circumstances in which it was created. It includes the hash of the previous block’s header, the version of the software the block is mined with, the timestamp and the merkle root hash of the contents of the block.
+The block header is a collection of metadata about a block and a summary of the transactions included in the execution payload.
### block propagation {#block-propagation}
The process of transmitting a confirmed block to all other nodes in the network.
+### block proposer {#block-proposer}
+
+The specific validator chosen to create a block in a particular [slot](#slot).
+
### block reward {#block-reward}
-The amount of ether rewarded to the producer of a new valid block.
+The amount of ether rewarded to the proposer of a new valid block.
+
+### block status {#block-status}
+
+The states that a block can exist in. The possible states include:
+
+- proposed: the block was proposed by a validator
+- scheduled: validators are currently submitting data
+- missed/skipped: the proposer did not propose a block within the eligible time frame.
+- orphaned: the block was reorg'd out by the [fork choice algorithm](#fork-choice-algorithm)
### block time {#block-time}
-The average time interval between blocks being added to the blockchain.
+The time interval between blocks being added to the blockchain.
### block validation {#block-validation}
-Checking of the coherence of the cryptographic signature of the block with the history stored in the entire blockchain.
+The process of checking that a new block contains valid transactions and signatures, builds on the heaviest historical chain, and follows all other consensus rules. Valid blocks are added to the end of the chain and propagated to others on the network. Invalid blocks are disregarded.
### blockchain {#blockchain}
-In Ethereum, a sequence of [blocks](#block) validated by the [proof-of-work](#pow) system, each linking to its predecessor all the way to the [genesis block](#genesis-block). There is no block size limit; it instead uses varying [gas limits](#gas-limit).
+A sequence of [blocks](#block), each linking to its predecessor all the way to the [genesis block](#genesis-block) by referencing the hash of the previous block. The integrity of the blockchain is crypto-economically secured using a proof-of-stake-based consensus mechanism.
- What is a Blockchain?
+ What is a blockchain?
### bootnode {#bootnode}
@@ -161,7 +174,7 @@ Converting code written in a high-level programming language (e.g., [Solidity](#
### committee {#committee}
-A group of at least 128 [validators](#validator) assigned to beacon and shard blocks at random by [the Beacon Chain](#beacon-chain).
+A group of at least 128 [validators](#validator) assigned to validate blocks in each slot. One of the validators in the committee is the aggregator, responsible for aggregating the signatures of all other validators in the committee that agree on an attestation. Not to be confused with [sync committee](#sync-committee).
### computational infeasibility {#computational-infeasibility}
@@ -169,7 +182,7 @@ A process is computationally infeasible if it would take an impracticably long t
### consensus {#consensus}
-When numerous nodes (usually most nodes on the network) all have the same blocks in their locally validated best blockchain. Not to be confused with [consensus rules](#consensus-rules).
+When a supermajority of nodes on the network all have the same blocks in their locally validated best blockchain. Not to be confused with [consensus rules](#consensus-rules).
### consensus client {#consensus-client}
@@ -195,16 +208,6 @@ An account containing code that executes whenever it receives a [transaction](#t
A special [transaction](#transaction), with the [zero address](#zero-address) as the recipient, that is used to register a [contract](#contract-account) and record it on the Ethereum blockchain.
-### crosslink {#crosslink}
-
-A crosslink provides a summary of a shard's state. It's how [shard](#shard) chains will communicate with one another via the [Beacon Chain](#beacon-chain) in the sharded [proof-of-stake system](#proof-of-stake).
-
-
- Proof-of-stake
-
-
-
-
### cryptoeconomics {#cryptoeconomics}
The economics of cryptocurrencies.
@@ -217,7 +220,7 @@ The economics of cryptocurrencies.
### DAG {#dag}
-DAG stands for Directed Acyclic Graph. It is a data structure composed of nodes and links between them. Ethereum uses a DAG in its [proof of work](#proof-of-work) algorithm, [Ethash](#ethash).
+DAG stands for Directed Acyclic Graph. It is a data structure composed of nodes and links between them. Ethereum uses a DAG in its [proof-of-work](#pow) algorithm, [Ethash](#ethash).
### Dapp {#dapp}
@@ -255,6 +258,10 @@ A type of [dapp](#dapp) that lets you swap tokens with peers on the network. You
See [non-fungible token (NFT)](#nft).
+### deposit contract {#deposit-contract}
+
+The gateway to staking on Ethereum. The deposit contract is a smart contract on Ethereum that accepts deposits of ETH and manages validator balances. A validator cannot be activated without depositing ETH into this contract. The contract requires ETH and input data. This input data includes the validator public key and withdrawal public key, signed by the validator private key. This data is needed for a validator to be identified and approved by the [proof-of-stake](#pos) network.
+
### DeFi {#defi}
Short for "decentralized finance," a broad category of [dapps](#dapp) aiming to provide financial services backed by the blockchain, without any intermediaries, so anyone with an internet connection can participate.
@@ -265,11 +272,11 @@ Short for "decentralized finance," a broad category of [dapps](#dapp) aiming to
### difficulty {#difficulty}
-A network-wide setting that controls how much computation is required to produce a [proof-of-work](#pow).
+A network-wide setting in [proof-of-work](#pow) networks that controls how much average computation is required to find a valid nonce. The difficulty is represented by the number of leading zeroes that are required in the resulting block hash for it to be considered valid. This concept is deprecated in Ethereum since the transition to proof-of-stake.
### difficulty bomb {#difficulty-bomb}
-Planned exponential increase in [proof-of-work](#pow) [difficulty](#difficulty) setting designed to motivate the transition to [proof-of-stake](#pos), reducing the chances of a [fork](#hard-fork).
+Planned exponential increase in [proof-of-work](#pow) [difficulty](#difficulty) setting that was designed to motivate the transition to [proof-of-stake](#pos), reducing the chances of a [fork](#hard-fork). The difficulty bomb was deprecated with the [transition to proof-of-stake](/upgrades/merge).
### digital signature {#digital-signatures}
@@ -287,7 +294,7 @@ A data structure containing `(key, value)` pairs used by Ethereum nodes to ident
### double spend {#double-spend}
-A deliberate blockchain fork, where a user with a sufficiently large amount of mining power/stake sends a transaction moving some currency off-chain (e.g. exiting into fiat money or making an off-chain purchase) then reorganising the blockchain to remove that transaction. A successful double spend leaves the attacker with both their on and off-chain assets.
+A deliberate blockchain fork, where a user with a sufficiently large amount of mining power/stake sends a transaction moving some currency off-chain (e.g. exiting into fiat money or making an off-chain purchase) then reorganizing the blockchain to remove that transaction. A successful double spend leaves the attacker with both their on and off-chain assets.
## E {#section-e}
@@ -305,7 +312,7 @@ In the context of cryptography, lack of predictability or level of randomness. W
### epoch {#epoch}
-A period of 32 [slots](#slot) (6.4 minutes) in the [Beacon Chain](#beacon-chain)-coordinated system. [Validator](#validator) [committees](#committee) are shuffled every epoch for security reasons. There's an opportunity at each epoch for the chain to be [finalized](#finality). The term is also used on the [execution layer](#execution-layer) to mean the interval between each regeneration of the database used as a seed by the proof-of-work algorithm [Ethash](#Ethash). The epoch in specified as 30000 blocks.
+A period of 32 [slots](#slot), each slot being 12 seconds, totalling 6.4 minutes. Validator [committees](#committee) are shuffled every epoch for security reasons. Each epoch has an opportunity for the chain to be [finalized](#finality). Each validator is assigned new responsibilities at the start of each epoch.
Proof-of-stake
@@ -331,10 +338,6 @@ A validator sending two messages that contradict each other. One simple example
More on the Ethereum upgrades
-### etherbase {#etherbase}
-
-The default name of the primary account on an Ethereum client. Mining rewards are credited to this account. This is an Ethereum-specific version of "coinbase" which is applicable to other cryptocurrencies.
-
### Ethereum Improvement Proposal (EIP) {#eip}
A design document providing information to the Ethereum community, describing a proposed new feature or its processes or environment (see [ERC](#erc)).
@@ -351,7 +354,7 @@ The ENS registry is a single central [contract](#smart-contract) that provides a
### execution client {#execution-client}
-Execution clients (f.k.a. "Eth1 clients"), such as Besu, Erigon, go-ethereum, Nethermind, are tasked with processing and broadcasting transactions, as well as with managing Ethereum's state. They run the computations for each transaction in the [Ethereum Virtual Machine](#evm) to ensure that the rules of the protocol are followed. Today, they also handle [proof-of-work](#pow) consensus. After the transition to [proof-of-stake](#pos), they will delegate this to consensus clients.
+Execution clients (formerly known as "Eth1 clients"), such as Besu, Erigon, Go-Ethereum (Geth), Nethermind, are tasked with processing and broadcasting transactions and managing Ethereum's state. They run the computations for each transaction using the [Ethereum Virtual Machine](#evm) to ensure that the rules of the protocol are followed.
### execution layer {#execution-layer}
@@ -359,7 +362,7 @@ Ethereum's execution layer is the network of [execution clients](#execution-clie
### externally owned account (EOA) {#eoa}
-Externally owned accounts (EOAs) are [accounts](#account) that are controlled by users who control the [private keys](#private-key) for an account, typically generated using a [seed phrase](#hd-wallet-seed). Externally owned accounts are accounts without any code associated with them. Typically these accounts are used with a [wallet](#wallet).
+Externally owned accounts (EOAs) are [accounts](#account) that are controlled by [private keys](#private-key), typically generated using a [seed phrase](#hd-wallet-seed). Unlike smart contracts, externally owned accounts are accounts without any code associated with them. Typically these accounts are managed with a [wallet](#wallet).
### Ethereum Request for Comments (ERC) {#erc}
@@ -371,9 +374,9 @@ A label given to some [EIPs](#eip) that attempt to define a specific standard of
### Ethash {#ethash}
-A [proof-of-work](#pow) algorithm for Ethereum 1.0.
+A [proof-of-work](#pow) algorithm that was used on Ethereum before it transitioned to [proof-of-stake](#pos).
-[Read more at eth.wiki](https://eth.wiki/en/concepts/ethash/ethash)
+[Read more](/developers/docs/consensus-mechanisms/pow/mining-algorithms/ethash)
### ether {#ether}
@@ -416,16 +419,13 @@ A default function called in the absence of data or a declared function name.
A service carried out via [smart contract](#smart-contract) that dispenses funds in the form of free test ether that can be used on a testnet.
- Testnet Faucets
+ Testnet faucets
### finality {#finality}
Finality is the guarantee that a set of transactions before a given time will not change and can't be reverted.
-
- Proof-of-work finality
-
Proof-of-stake finality
@@ -436,7 +436,7 @@ A denomination of [ether](#ether). 1 finney = 1015 [wei](#wei). 10
-### lightweight client {#lightweight-client}
+### light client {#light-client}
An Ethereum client that does not store a local copy of the [blockchain](#blockchain), or validate blocks and [transactions](#transaction). It offers the functions of a [wallet](#wallet) and can create and broadcast transactions.
@@ -644,15 +644,11 @@ The third development stage of Ethereum, launched in October 2017.
### mining {#mining}
-The process of verifying transactions and contract execution on the Ethereum blockchain in exchange for a reward in ether with the mining of every block.
-
-### mining pool {#mining-pool}
-
-The pooling of resources by miners who share their processing power and split [block rewards](#block-reward).
+The process of repeatedly hashing a block header while incrementing a [nonce](#nonce) until the result contains an arbitrary number of leading binary zeros. This is the process by which new [blocks](#block) are added to a proof-of-work [blockchain](#blockchain). This was how Ethereum was secured before it moved to [proof-of-stake](#pos).
### miner {#miner}
-A network [node](#node) that finds valid [proof-of-work](#pow) for new blocks, by repeated pass hashing (see [Ethash](#ethash)).
+A network [node](#node) that finds valid [proof-of-work](#pow) for new blocks, by repeated pass hashing (see [Ethash](#ethash)). Miners are no longer part of Ethereum - they were replaced by validators when Ethereum moved to [proof-of-stake](#pos).
Mining
@@ -676,7 +672,7 @@ Referring to the Ethereum network, a peer-to-peer network that propagates transa
### network hashrate {#network-hashrate}
-The collective [hashrate](#hashrate) produced by the entire Ethereum mining network.
+The collective [hashrate](#hashrate) produced by an entire mining network. Mining on Ethereum was switched off when Ethereum moved to [proof-of-stake](#pos).
### non-fungible token (NFT) {#nft}
@@ -699,7 +695,7 @@ A software client that participates in the network.
### nonce {#nonce}
-In cryptography, a value that can only be used once. There are two types of nonce used in Ethereum- an account nonce is a transaction counter in each account, which is used to prevent replay attacks; a [proof-of-work](#pow) nonce is the random value in a block that was used to satisfy the [proof-of-work](#pow).
+In cryptography, a value that can only be used once. An account nonce is a transaction counter in each account, which is used to prevent replay attacks.
@@ -707,7 +703,7 @@ In cryptography, a value that can only be used once. There are two types of nonc
### ommer (uncle) block {#ommer}
-When a [miner](#miner) finds a valid [block](#block), another miner may have published a competing block which is added to the tip of the blockchain first. This valid, but stale, block can be included by newer blocks as _ommers_ and receive a partial block reward. The term "ommer" is the preferred gender-neutral term for the sibling of a parent block, but this is also sometimes referred to as an "uncle".
+When a proof-of-work [miner](#miner) finds a valid [block](#block), another miner may have published a competing block which is added to the tip of the blockchain first. This valid, but stale, block can be included by newer blocks as _ommers_ and receive a partial block reward. The term "ommer" is the preferred gender-neutral term for the sibling of a parent block, but this is also sometimes referred to as an "uncle". This was relevant for Ethereum when it was a [proof-of-work](pow) network, but ommers are not a feature of [proof-of-stake](#pos) Ethereum because precisely one block proposer is selected in each slot.
### optimistic rollup {#optimistic-rollup}
@@ -767,7 +763,7 @@ A method by which a cryptocurrency blockchain protocol aims to achieve distribut
### proof-of-work (PoW) {#pow}
-A piece of data (the proof) that requires significant computation to find. In Ethereum, [miners](#miner) must find a numeric solution to the [Ethash](#ethash) algorithm that meets a network-wide [difficulty](#difficulty) target.
+A piece of data (the proof) that requires significant computation to find.
Proof-of-work
@@ -835,7 +831,7 @@ The process of converting a data structure into a sequence of bytes.
### shard / shard chain {#shard}
-A [proof-of-stake](#pos) chain that is coordinated by the [Beacon Chain](#beacon-chain) and secured by [validators](#validator). There will be 64 added to the network as part of the shard chain upgrade. Shard chains will offer increased transaction throughput for Ethereum by providing additional data to [layer 2](#layer-2) solutions like [optimistic rollups](#optimistic-rollups) and [ZK-rollups](#zk-rollups).
+Shard chains are discrete sections of the total blockchain that can subsets of validators can be responsible for. This will offer increased transaction throughput for Ethereum and improve data availability for [layer 2](#layer-2) solutions like [optimistic rollups](#optimistic-rollups) and [ZK-rollups](#zk-rollups).
Shard chains
@@ -857,9 +853,13 @@ Demonstrating cryptographically that a transaction was approved by the holder of
A computer programming term that describes an object of which only a single instance can exist.
+### slasher {#slasher}
+
+A slasher is an entity that scans attestations searching for slashable offenses. Slashings are broadcast to the network, and the next block proposer adds the proof to the block. The block proposer then receives a reward for slashing the malicious validator.
+
### slot {#slot}
-A period of time (12 seconds) in which a new [Beacon Chain](#beacon-chain) and [shard](#shard) chain block can be proposed by a [validator](#validator) in the [proof-of-stake](#pos) system. A slot may be empty. 32 slots make up an [epoch](#epoch).
+A period of time (12 seconds) in which a new blocks can be proposed by a [validator](#validator) in the [proof-of-stake](#pos) system. A slot may be empty. 32 slots make up an [epoch](#epoch).
Proof-of-stake
@@ -917,6 +917,14 @@ Depositing a quantity of [ether](#ether) (your stake) to become a validator and
Stake your ETH to become an Ethereum validator
+### staking pool {#staking-pool}
+
+The combined ETH of more than one Ethereum staker, used to reach the 32 ETH required to activate a set of validator keys. A node operator uses these keys to participate in consensus and the [block rewards](#block-reward) are split amongst contributing stakers. Staking pools or delegating staking are not native to the Ethereum protocol, but many solutions have been built by the community.
+
+
+ Pooled staking
+
+
### STARK {#stark}
Short for "scalable transparent argument of knowledge", a STARK is a type of [zero-knowledge proof](#zk-proof).
@@ -939,7 +947,7 @@ A [layer 2](#layer-2) solution where a channel is set up between participants, w
### supermajority {#supermajority}
-Supermajority is the term given for an amount exceeding 2/3 (66%) of the total staked ether on the [Beacon Chain](#beacon-chain). A supermajority vote is required for blocks to be [finalized](#finality) on the Beacon Chain.
+Supermajority is the term given for an amount exceeding 2/3 (66%) of the total staked ether securing Ethereum. A supermajority vote is required for blocks to be [finalized](#finality) on the Beacon Chain.
### syncing {#syncing}
@@ -947,7 +955,7 @@ The process of downloading the entire latest version of a blockchain to a node.
### sync committee {#sync-committee}
-A sync committee is a randomly selected group of [validators](#validator) on the [Beacon Chain](#beacon-chain) that refresh every ~27 hours. Their purpose is to add their signatures to valid block headers. Sync committees allow [light clients](#lightweight-client) to keep track of the head of the blockchain without having to access the entire validator set.
+A sync committee is a randomly selected group of [validators](#validator) that refresh every ~27 hours. Their purpose is to add their signatures to valid block headers. Sync committees allow [light clients](#light-client) to keep track of the head of the blockchain without needing to access the entire validator set.
### szabo {#szabo}
@@ -963,7 +971,7 @@ A [hard fork](#hard-fork) of the Ethereum blockchain, which occurred at block 2,
### terminal total difficulty (TTD) {#terminal-total-difficulty}
-The total difficulty is the sum of the Ethash mining difficulty for all blocks up to some specific point in the blockchain. The terminal total difficulty is a specific value for the total difficulty that will be used as the trigger for execution clients to switch off their mining and block gossip functions so the network can transition to proof-of-stake.
+The total difficulty is the sum of the Ethash mining difficulty for all blocks up to some specific point in the blockchain. The terminal total difficulty is a specific value for the total difficulty that was used as the trigger for execution clients to switch off their mining and block gossip functions enabling the network to transition to proof-of-stake.
### testnet {#testnet}
@@ -995,7 +1003,7 @@ Data committed to the Ethereum Blockchain signed by an originating [account](#ac
### transaction fee {#transaction-fee}
-A fee you need to pay whenever you use the Ethereum network. Examples include sending funds from your [wallet](#wallet) or a [dapp](#dapp) interaction, like swapping tokens or buying a collectible. You can think of this like a service charge. This fee will change based on how busy the network is. This is because [miners](#miner), the people responsible for processing your transaction, are likely to prioritise transactions with higher fees – so congestion forces the price up.
+A fee you need to pay whenever you use the Ethereum network. Examples include sending funds from your [wallet](#wallet) or a [dapp](#dapp) interaction, like swapping tokens or buying a collectable. You can think of this like a service charge. This fee will change based on how busy the network is. This is because [validators](#validator), the people responsible for processing your transaction, are likely to prioritize transactions with higher fees – so congestion forces the price up.
At a technical level, your transaction fee relates to how much [gas](#gas) your transaction requires.
@@ -1024,6 +1032,16 @@ A [node](#node) in a [proof-of-stake](#pos) system responsible for storing data,
Staking in Ethereum
+### validator lifecycle {#validator-lifecycle}
+
+The sequence of states that a validator can exist in. These include:
+
+- deposited: At least 32 ETH has been deposited to the [deposit contract](#deposit-contract) by the validator
+- pending: the validator is in the activation queue waiting to be voted into the network by existing validators
+- active: currently attesting and proposing blocks
+- slashing: the validator has misbehaved and is being slashed
+- exiting: the validator has been flagged for exiting the network, either voluntarily or because they have been ejected.
+
### validity proof {#validity-proof}
A security model for certain [layer 2](#layer-2) solutions where, to increase speed, transactions are [rolled up](/#rollups) into batches and submitted to Ethereum in a single transaction. The transaction computation is done off-chain and then supplied to the main chain with a proof of their validity. This method increases the amount of transactions possible while maintaining security. Some [rollups](#rollups) use [fraud proofs](#fraud-proof).
diff --git a/src/content/governance/index.md b/src/content/governance/index.md
index 7bff3d0e388..92c1fa354e0 100644
--- a/src/content/governance/index.md
+++ b/src/content/governance/index.md
@@ -3,6 +3,7 @@ title: Ethereum Governance
description: An introduction to how decisions about Ethereum are made.
lang: en
sidebar: true
+postMergeBannerTranslation: page-upgrades-post-merge-banner-governance-ood
---
# Introduction to Ethereum governance {#introduction}
diff --git a/src/content/history/index.md b/src/content/history/index.md
index d381c534820..646f11f198a 100644
--- a/src/content/history/index.md
+++ b/src/content/history/index.md
@@ -26,6 +26,21 @@ Looking for future protocol upgrades? [Learn about upcoming upgrades to Ethereum
## 2022 {#2022}
+### Bellatrix {#bellatrix}
+
+Sep-06-2022 11:34:47 AM +UTC
+Epoch number: 144,896
+ETH price: $1,558 USD
+ethereum.org on waybackmachine
+
+#### Summary {#bellatrix-summary}
+
+The Bellatrix upgrade was the second scheduled upgrade for the [Beacon Chain](/upgrades/beacon-chain), preparing the chain for The Merge. It brings validator penalties to their full values for inactivity and slashable offenses. Bellatrix also includes an update to the fork choice rules to prepare the chain for The Merge and the transition from the last proof-of-work block to the first proof-of-stake block. This includes making consensus clients aware of the [terminal total difficulty](/glossary/#terminal-total-difficulty) of 58750000000000000000000.
+
+- [Read the Bellatrix upgrade specification](https://github.com/ethereum/consensus-specs/tree/dev/specs/bellatrix)
+
+---
+
### Gray Glacier {#gray-glacier}
Jun-30-2022 10:54:04 AM +UTC
@@ -80,7 +95,7 @@ The Arrow Glacier network upgrade pushed back the [difficulty bomb](/glossary/#d
#### Summary {#altair-summary}
-The Altair upgrade was the first scheduled upgrade for the [Beacon Chain](/upgrades/beacon-chain). It added support for "sync committees"—enabling light clients, and bringing validator inactivity and slashing penalties up to their full values.
+The Altair upgrade was the first scheduled upgrade for the [Beacon Chain](/upgrades/beacon-chain). It added support for "sync committees"—enabling light clients, and increased validator inactivity and slashing penalties as development progressed towards The Merge.
- [Read the Altair upgrade specification](https://github.com/ethereum/consensus-specs/tree/dev/specs/altair)
@@ -88,7 +103,7 @@ The Altair upgrade was the first scheduled upgrade for the [Beacon Chain](/upgra
Altair was the first major network upgrade that had an exact rollout time. Every upgrade prior had been based on a declared block number on the proof-of-work chain, where block times vary. The Beacon Chain does not require solving for proof-of-work, and instead works on a time-based epoch system consisting of 32 twelve-second "slots" of time where validators can propose blocks. This is why we knew exactly when we would hit epoch 74,240 and Altair became live!
-- [Beaconcha.in Glossary - Slots](https://kb.beaconcha.in/glossary#slots)
+- [Block time](/developers/docs/blocks/#block-time)
---
diff --git a/src/content/nft/index.md b/src/content/nft/index.md
index f6e09540ab1..0ea49c711e8 100644
--- a/src/content/nft/index.md
+++ b/src/content/nft/index.md
@@ -11,7 +11,6 @@ alt: An Eth logo being displayed via hologram.
summaryPoint1: A way to represent anything unique as an Ethereum-based asset.
summaryPoint2: NFTs are giving more power to content creators than ever before.
summaryPoint3: Powered by smart contracts on the Ethereum blockchain.
-preMergeBanner: true
---
NFTs are currently taking the digital art and collectibles world by storm. Digital artists are seeing their lives change thanks to huge sales to a new crypto-audience. And celebrities are joining in as they spot a new opportunity to connect with fans. But digital art is only one way to use NFTs. Really they can be used to represent ownership of any unique asset, like a deed for an item in the digital or physical realm.
@@ -20,7 +19,7 @@ If Andy Warhol had been born in the late 90s, he probably would have minted Camp
## What's an NFT? {#what-are-nfts}
-NFTs are tokens that we can use to represent ownership of unique items. They let us tokenise things like art, collectibles, even real estate. They can only have one official owner at a time and they're secured by the Ethereum blockchain – no one can modify the record of ownership or copy/paste a new NFT into existence.
+NFTs are tokens that we can use to represent ownership of unique items. They let us tokenize things like art, collectibles, even real estate. Ownership of an asset is secured by the Ethereum blockchain – no one can modify the record of ownership or copy/paste a new NFT into existence.
NFT stands for non-fungible token. Non-fungible is an economic term that you could use to describe things like your furniture, a song file, or your computer. These things are not interchangeable for other items because they have unique properties.
@@ -96,7 +95,7 @@ NFTs are different from ERC-20 tokens, such as DAI or LINK, in that each individ
- Signatures
- Lots and lots more options to get creative with!
-An NFT can only have one owner at a time. Ownership is managed through the uniqueID and metadata that no other token can replicate. NFTs are minted through smart contracts that assign ownership and manage the transferability of the NFT's. When someone creates or mints an NFT, they execute code stored in smart contracts that conform to different standards, such as ERC-721. This information is added to the blockchain where the NFT is being managed. The minting process, from a high level, has the following steps that it goes through:
+Ownership of NFTs is managed through the unique ID and metadata that no other token can replicate. NFTs are minted through smart contracts that assign ownership and manage the transferability of the NFT's. When someone creates or mints an NFT, they execute code stored in smart contracts that conform to different standards, such as [ERC-721](/developers/docs/standards/tokens/erc-721/). This information is added to the blockchain where the NFT is being managed. The minting process, from a high level, has the following steps that it goes through:
- Creating a new block
- Validating information
@@ -291,11 +290,10 @@ NFTs are growing in popularity which means they're also coming under increased s
To clarify a few things:
-- NFTs aren't directly increasing the carbon footprint of Ethereum.
-- The way Ethereum keeps your funds and assets secure is currently energy-intensive but it's about to improve.
-- Once improved, Ethereum's carbon footprint will be 99.95% better, making it more energy efficient than many existing industries.
+- Creating and transferring NFTs are just Ethereum transactions - they have no direct impact on the energy expended by Ethereum, nor do they independently expend their own energy.
+- Ethereum is a low-energy blockchain, meaning the environmental impact of creating, buying and transferring NFTs is very small.
-To explain further we're going to have to get a little more technical so bear with us...
+The next sections explain further with a little more technical detail...
### Don't blame it on the NFTs {#nft-qualities}
@@ -305,67 +303,27 @@ Decentralized meaning you and everyone else can verify you own something. All wi
Secure meaning no one can copy/paste your NFT or steal it.
-These qualities of Ethereum makes digitally owning unique items and getting a fair price for your content possible. But it comes at a cost. Blockchains like Bitcoin and Ethereum are energy intensive right now because it takes a lot of energy to preserve these qualities. If it was easy to rewrite Ethereum's history to steal NFTs or cryptocurrency, the system collapses.
+These qualities of Ethereum makes digitally owning unique items and getting a fair price for your content possible. Ethereum protects the assets using a decentralized consensus mechanism which involves ['proof-of-stake'](/developers/docs/consensus-mechanisms/pos). This is a low carbon method to determine who can add a block of transactions to the chain, and is considered more secure than the energy-intensive alternative, ['proof-of-work'](/developers/docs/consensus-mechanisms/pow). NFTs have been associated with high energy expenditure because Ethereum used to be secured using proof-of-work. This is no longer true.
-#### The work in minting your NFT {#minting-nfts}
+#### Minting NFTs {#minting-nfts}
When you mint an NFT, a few things have to happen:
- It needs to be confirmed as an asset on the blockchain.
- The owner's account balance must be updated to include that asset. This makes it possible for it to then be traded or verifiably "owned".
-- The transactions that confirm the above need to be added to a block and "immortalised" on the chain.
-- The block needs to be confirmed by everyone in the network as "correct". This consensus removes the need for intermediaries because the network agrees that your NFT exists and belongs to you. And it's on chain so anyone can check it. This is one of the ways Ethereum helps NFT creators to maximise their earnings.
+- The transactions that confirm the above need to be added to a block and "immortalized" on the chain.
+- The block needs to be confirmed by everyone in the network as "correct". This consensus removes the need for intermediaries because the network agrees that your NFT exists and belongs to you. And it's on chain so anyone can check it. This is one of the ways Ethereum helps NFT creators to maximize their earnings.
-All these tasks are done by miners. And they let the rest of the network know about your NFT and who owns it. This means mining needs to be sufficiently difficult, otherwise anyone could just claim that they own the NFT you just minted and fraudulently transfer ownership. There are lots of incentives in place to make sure miners are acting honestly.
+All these tasks are done by block producers and validators. Block proposers add your NFT transaction to a block and broadcast it to the rest of the network. Validators check that the transaction is valid and then add it to their databases. There are lots of crypto-economic incentives in place to make sure validators are acting honestly. Otherwise, anyone could just claim that they own the NFT you just minted and fraudulently transfer ownership.
-[More on mining](/developers/docs/consensus-mechanisms/pow/)
+#### NFT security {#nft-security}
-#### Securing your NFT with mining {#securing-nfts}
+Ethereum's security comes from proof-of-stake. The system is designed to economically disincentivize malicious actions, making Ethereum tamper-proof. This is what makes NFTs possible. Once the block containing your NFT transaction becomes finalized it would cost an attacker millions of ETH to change it. Anyone running Ethereum software would immediately be able to detect dishonest tampering with an NFT, and the bad actor would be economically penalized and ejected.
-Mining difficulty comes from the fact that it takes a lot of computing power to create new blocks in the chain. Importantly, blocks are created consistently, not just when they're needed. They're created every 12 seconds or so.
+Security issues relating to NFTs are most often related to phishing scams, smart contract vulnerabilities or user errors (such as inadvertently exposing private keys), making good wallet security critical for NFT owners.
-This is important for making Ethereum tamper-proof, one of the qualities that makes NFTs possible. The more blocks the more secure the chain. If your NFT was created in block #600 and a hacker were to try and steal your NFT by modifying its data, the digital fingerprint of all subsequent blocks would change. That means anyone running Ethereum software would immediately be able to detect and prevent it from happening.
-
-However this means that computing power needs to be used constantly. It also means that a block that contains 0 NFT transactions will still have roughly the same carbon footprint, because computing power will still be consumed to create it. Other non-NFT transactions will fill the blocks.
-
-#### Blockchains are energy intensive, right now {#blockchains-intensive}
-
-So yes, there is a carbon footprint associated with creating blocks by mining – and this is a problem for chains like Bitcoin too – but it's not directly the fault of NFTs.
-
-A lot of mining uses renewable energy sources or untapped energy in remote locations. And there is the argument that the industries that NFTs and cryptocurrencies are disrupting have huge carbon footprints too. But just because existing industries are bad, doesn't mean we shouldn't strive to be better.
-
-And we are. Ethereum is evolving to make using Ethereum (and by virtue, NFTs) more energy efficient. And that's always been the plan.
-
-We're not here to defend the environmental footprint of mining, instead we want to explain how things are changing for the better.
-
-### A greener future... {#a-greener-future}
-
-For as long as Ethereum has been around, the energy-consumption of mining has been a huge focus area for developers and researchers. And the vision has always been to replace it as soon as possible. [More on Ethereum's vision](/upgrades/vision/)
-
-This vision is being delivered right now.
-
-#### A greener Ethereum {#greener-ethereum}
-
-Ethereum is currently going through a series of upgrades that will replace mining with [staking](/staking/). This will remove computing power as a security mechanism, and reduce Ethereum's carbon footprint by ~99.95%[^1]. In this world, stakers commit funds instead of computing power to secure the network.
-
-The energy-cost of Ethereum will become the cost of running a home computer multiplied by the number of nodes in the network. If there are 10,000 nodes in the network and the cost of running a home computer is roughly 525kWh per year. That's 5,250,000kWh[^1] per year for the entire network.
-
-We can use this to compare the future of Ethereum to a global service like Visa. 100,000 Visa transactions uses 149kWh of energy[^2]. In proof-of-stake Ethereum, that same number of transactions would cost 17.4kWh of energy or ~11% of the total energy[^3]. That's without considering the many optimizations being worked on in parallel to the consensus layer and shard chains, like [rollups](/glossary/#rollups). It could be as little as 0.1666666667kWh of energy for 100,000 transactions.
-
-Importantly this improves the energy efficiency while preserving Ethereum's decentralization and security. Many other blockchains out there might already use some form of staking, but they're secured by a select few stakers, not the thousands that Ethereum will have. The more decentralization, the more secure the system.
-
-[More on energy estimates](#footnotes-and-sources)
-
-_We’ve provided the basic comparison to Visa to baseline your understanding of proof-of-stake Ethereum energy consumption against a familiar name. However, in practice, it’s not really correct to compare based on number of transactions. Ethereum’s energy output is time-based. If Ethereum did more or less transactions from one minute to the next, the energy output would stay the same._
-
-_It’s also important to remember that Ethereum does more than just financial transactions, it’s a platform for applications, so a fairer comparison might be to many companies/industries including Visa, AWS and more!_
-
-#### Timelines {#timelines}
-
-The process has already started. [The Beacon Chain](/upgrades/beacon-chain/), the first upgrade, shipped in December 2020. This provides the foundation for staking by allowing stakers to join the system. The next step relevant to energy efficiency is to merge the current chain, the one secured by miners, into the Beacon Chain where mining isn't needed. Timelines can't be exact at this stage, but it's estimated that this will happen sometime in 2022. This process is known as The Merge (formerly referred to as the docking). [More on The Merge](/upgrades/merge/).
-
-
- More on Ethereum upgrades
+
+ More on security
## Build with NFTs {#build-with-nfts}
@@ -379,71 +337,5 @@ Most NFTs are built using a consistent standard known as [ERC-721](/developers/d
- [A beginner's guide to NFTs](https://linda.mirror.xyz/df649d61efb92c910464a4e74ae213c4cab150b9cbcc4b7fb6090fc77881a95d) – _Linda Xie, January 2020_
- [Everything you need to know about the metaverse](https://foundation.app/blog/enter-the-metaverse) – _Foundation team, foundation.app_
- [No, CryptoArtists Aren’t Harming the Planet](https://medium.com/superrare/no-cryptoartists-arent-harming-the-planet-43182f72fc61)
+- [Ethereum's energy consumption](/energy-consumption/)
- [A country's worth of power, no more](https://blog.ethereum.org/2021/05/18/country-power-no-more/) – _Carl Beekhuizen, May 18 2021_
-
-
-
-### Footnotes and sources {#footnotes-and-sources}
-
-This explains how we arrived at our energy estimates above. These estimates apply to the network as a whole and are not just reserved for the process of creating, buying, or selling NFTs.
-
-#### 1. 99.95% energy reduction from mining {#fn-1}
-
-The 99.95% reduction in energy consumption from a system secured by mining to a system secured by staking is calculated using the following data sources:
-
-- 44.49 TWh of annualized electrical energy is consumed by mining Ethereum - [Digiconomist](https://digiconomist.net/ethereum-energy-consumption)
-
-- The average desktop computer, all that's needed to run proof-of-stake, uses 0.06kWh of energy per hour – [Silicon Valley power chart](https://www.siliconvalleypower.com/residents/save-energy/appliance-energy-use-chart) (Some estimates are a little higher at 0.15kWh)
-
-At the time of writing, there are 140 592 validators from 16 405 unique addresses.
-Of those, 87 897 validators are assumed to be staking from home.
-
-It is assumed the average person staking from home uses a 100 watt desktop personal computer setup to run an average of 5.4 validator clients.
-
-The 87 897 validators running from home gives us 16 300 users consuming ~1.64 megawatt of energy.
-
-The rest of the validators are run by custodial stakers such as exchanges and staking services.
-It can be assumed that they use 100w per 5.5 validators. This is a gross overestimation to be on the safe side.
-
-In total, Ethereum on proof-of-stake therefore consumes something on the order of 2.62 megawatt, which is about the same as a small American town.
-
-This is a reduction of at least 99.95% in total energy usage from the Digiconomist estimate of 44.94 TWh per year that the Ethereum miners currently consume.
-
-#### 2. Visa energy consumption {#fn-2}
-
-The cost of 100,000 Visa transactions is 149 kwH - [Bitcoin network average energy consumption per transaction compared to VISA network as of 2020, Statista](https://www.statista.com/statistics/881541/bitcoin-energy-consumption-transaction-comparison-visa/)
-
-Year-ending September 2020 they processed 140,839,000,000 transactions – [Visa financials report Q4 2020](https://s1.q4cdn.com/050606653/files/doc_financials/2020/q4/Visa-Inc.-Q4-2020-Operational-Performance-Data.pdf)
-
-#### 3. Energy usage for 100,000 transactions on a sharded proof-of-stake network {#fn-3}
-
-It's estimated that scalability upgrades will allow the network to process between 25,000 and 100,000 transactions per second, with [100,000 as the theoretical maximum right now](https://ethereum-magicians.org/t/a-rollup-centric-ethereum-roadmap/4698).
-
-[Vitalik Buterin on transactions per second potential with sharding](https://twitter.com/VitalikButerin/status/1312905884549300224)
-
-At the bare minimum, sharding will allow 64 times the amount of transactions as today which sits at around 15 transactions. That's the amount of shard chains (extra data and capacity) being introduced. [More on shard chains](/upgrades/sharding/)
-
-That means we can estimate how long it will take to process 100,000 transactions so we can compare it to the Visa example above.
-
-- `15 * 64 = 960` transactions per second.
-- `100,000 / 960 = 104.2` seconds to process 100,000 transactions.
-
-In 104.2 seconds, the Ethereum network will use the following amount of energy:
-
-`1.44kWh daily usage * 10,000 network nodes = 14,400kWh` per day.
-
-There are 86,400 seconds in a day, so `14,400 / 86,400 = 0.1666666667kWh` per second.
-
-If we multiply that by the amount of time it takes to process 100,000 transaction: `0.1666666667 * 104.2 = 17.3666666701 kWh`.
-
-That is **11.6554809866%** of the energy consumed by the same amount of transactions on Visa.
-
-And remember, this is based on the minimum amount of transactions that Ethereum will be able to handle per second. If Ethereum reaches its potential of 100,000 transactions per second, 100,000 transactions would consume 0.1666666667kWh.
-
-To put it another way, if Visa handled 140,839,000,000 transactions at a cost of 149 kWh per 100,000 transactions that's 209,850,110 kWh energy consumed for the year.
-
-Ethereum in a single year stands to consume 5,256,000 kWh. With a potential of 788,940,000,000 - 3,153,600,000,000 transactions processed in that time.
-
-
- If you think these stats are incorrect or can be made more accurate, please raise an issue or PR. These are estimates by the ethereum.org team made using publicly accessible information and the planned Ethereum design. This doesn't represent an official promise from the Ethereum Foundation.
-
diff --git a/src/content/security/index.md b/src/content/security/index.md
index a59d4829be2..5cbe8cc95ea 100644
--- a/src/content/security/index.md
+++ b/src/content/security/index.md
@@ -214,6 +214,14 @@ As a general rule, staff will never communicate with you through private, unoffi
+### 'Eth2' token scam {#eth2-token-scam}
+
+In the run-up to [The Merge](/upgrades/merge/), scammers took advantage of the confusion around the term 'Eth2' to try and get users to redeem their ETH for an 'ETH2' token. There is no 'ETH2', and no other legitimate token was introduced with The Merge. The ETH that you owned before The Merge is the same ETH now. There is **no need to take any action related to your ETH to account for the switch from proof-of-work to proof-of-stake**.
+
+Scammers may appear as "support", telling you that if you deposit your ETH, you will receive back 'ETH2'. There is no [official Ethereum support](/community/support/), and there is no new token. Never share your wallet seed phrase with anyone.
+
+_Note: There are derivative tokens/tickers that may represent staked ETH (ie. rETH from Rocket Pool, stETH from Lido, ETH2 from Coinbase), but these are not something you need to "migrate to."_
+
### Phishing scams {#phishing-scams}
Phishing scams are another increasingly common angle that scammers will use to attempt to steal your wallet's funds.
@@ -240,7 +248,7 @@ These fraudulent brokers find their targets by using fake accounts on YouTube to
### Crypto mining pool scams {#mining-pool-scams}
-Mining pool scams involve people contacting you unsolicited, and claiming that you can make large returns by joining an Ethereum mining pool. The scammer will make claims and stay in contact with you for however long it takes. Essentially, the scammer will try and convince you that when you join an Ethereum mining pool, your cryptocurrency will be used to create ETH and that you will be paid dividends in the form of ETH. What will end up happening is, you will notice that your cryptocurrency is making small returns. This is simply to bait you into investing more. Eventually, all of your funds will be sent to an unknown address and the scammer will either disappear or in some cases will continue to stay in touch as has happened in a recent case.
+As of September 2022, mining on Ethereum is no longer possible. However, mining pool scams still exist. Mining pool scams involve people contacting you unsolicited and claiming that you can make large returns by joining an Ethereum mining pool. The scammer will make claims and stay in contact with you for however long it takes. Essentially, the scammer will try and convince you that when you join an Ethereum mining pool, your cryptocurrency will be used to create ETH and that you will be paid dividends in the form of ETH. What will end up happening is, you will notice that your cryptocurrency is making small returns. This is simply to bait you into investing more. Eventually, all of your funds will be sent to an unknown address, and the scammer will either disappear or in some cases will continue to stay in touch as has happened in a recent case.
Bottom line, be wary of people who contact you on social media asking for you to be part of a mining pool. Once you lose your crypto, it is gone.
@@ -252,14 +260,6 @@ Some things to remember:
[Man loses $200k in mining pool scam](https://www.reddit.com/r/CoinBase/comments/r0qe0e/scam_or_possible_incredible_payout/)
-### 'Eth2' token scam {#eth2-token-scam}
-
-With [The Merge](/upgrades/merge/) coming in 2022, scammers have taken advantage of the confusion around the term 'Eth2' to try and get users to redeem their ETH for an 'ETH2' token. There is no 'ETH2' or any other new token introduced with The Merge. The ETH that you own today will continue to be the same ETH after The Merge, and there is no need to do any swaps of your ETH for The Merge.
-
-Scammers may appear in the form of "support" telling you if you deposit your ETH you will receive back 'ETH2'. There is no [official Ethereum support](/community/support/), and there is no new token. Never share your wallet seed phrase with anyone.
-
-_Note: There are derivative tokens/tickers that may represent staked ETH (ie. rETH from Rocket Pool, stETH from Lido, ETH2 from Coinbase), but these are not something you need to "migrate to."_
-
### Airdrop scams {#airdrop-scams}
Airdrop scams involve a scam project airdropping an asset (NFT, token) into your wallet and sending you to a scam website to claim the airdropped asset. You will get prompted to sign in with your Ethereum wallet and "approve" a transaction when attempting to claim. This transaction compromises your account by sending your public and private keys to the scammer. An alternative form of this scam may have you confirm a transaction that sends funds to the scammer's account.
diff --git a/src/content/social-networks/index.md b/src/content/social-networks/index.md
index 72ed449620f..96b4cc78311 100644
--- a/src/content/social-networks/index.md
+++ b/src/content/social-networks/index.md
@@ -80,7 +80,7 @@ Reddit has [touted Community Points](https://cointelegraph.com/news/reddit-to-re
The program is already live, with the r/CryptoCurrency subreddit [running its version of Community Points called "Moons"](https://www.reddit.com/r/CryptoCurrency/wiki/moons_wiki). Per the official description, Moons "reward posters, commenters, and moderators for their contributions to the subreddit." Because these tokens are on the blockchain (users receive them in wallets), they are independent of Reddit and cannot be taken away.
-After concluding a beta phase on the Rinkeby testnet, Reddit Community Points are now on [Arbitrum Nova](https://nova.arbitrum.io/), a blockchain that combines properties of a [sidechain](/developers/docs/scaling/sidechains/) and an [optimistic rollup](/developers/docs/scaling/optimistic-rollups/). Besides using Community Points to unlock special features, users can also trade them for fiat on exchanges. Also, the amount of Community Points a user owns determines their influence on the decision-making process within the community.
+After concluding a beta phase on the Rinkeby testnet, Reddit Community Points are now on [Arbitrum Nova](https://nova.arbitrum.io/), a blockchain that combines properties of a [validium](/developers/docs/scaling/validium/) and an [optimistic rollup](/developers/docs/scaling/optimistic-rollups/). Besides using Community Points to unlock special features, users can also trade them for fiat on exchanges. Also, the amount of Community Points a user owns determines their influence on the decision-making process within the community.
### Twitter {#twitter}
diff --git a/src/content/staking/pools/index.md b/src/content/staking/pools/index.md
index b1e24cca95a..a030cf6de9b 100644
--- a/src/content/staking/pools/index.md
+++ b/src/content/staking/pools/index.md
@@ -67,17 +67,10 @@ Typically ERC-20 liquidity tokens are issued to stakers that represents the valu
-Currently, withdrawing funds from a validator on the Beacon Chain is not possible, which currently limits the ability to actually redeem your liquidity token for the ETH rewards locked in the consensus layer.
-Alternatively, pools that utilize an ERC-20 liquidity token allow users to trade this token in the open market, effectively allowing you to "withdraw" without actually removing ETH from the Beacon Chain.
-
-
-
-Pooled stakers do not need to do anything to prepare for The Merge.
-
-However, as The Merge approaches, be on high alert for scammers. **You do not need to upgrade your ETH or staked ETH tokens** for the transition to proof-of-stake.
+Currently, withdrawing funds from an Ethereum validator is not possible, which limits the ability to actually _redeem_ your liquidity token for the ETH rewards locked in the consensus layer.
-Learn more about [The Merge](/upgrades/merge/)
+Alternatively, pools that utilize an ERC-20 liquidity token allow users to trade this token in the open market, allowing you to sell your staking position, effectively "withdrawing" without actually removing ETH from the staking contract.
diff --git a/src/content/staking/saas/index.md b/src/content/staking/saas/index.md
index 14882386655..4fdccd37461 100644
--- a/src/content/staking/saas/index.md
+++ b/src/content/staking/saas/index.md
@@ -76,21 +76,7 @@ All of these keys can always be regenerated in a reproducible manner using your
- When you stake 32 ETH with a SaaS provider, that ETH is still deposited to the official staking deposit contract. As such, SaaS stakers are currently limited by the same withdrawal restrictions as solo stakers. This means that staking your ETH is currently a one-way deposit. This will be the case until the Shanghai upgrade planned to follow the Merge.
-
-
-
- After the Merge, SaaS stakers will begin to receive unburnt transaction fees/tips. Check with your provider to determine how to update your settings to include an Ethereum address you control where these funds will be sent when the time comes.
-
-The Merge will not enable the ability to withdraw your stake or protocol rewards; this feature is planned for the Shanghai upgrade, which will follow the Merge by an estimated six months to a year.
-
-
-
-SaaS stakers do not need to do anything to prepare for The Merge.
-
-There are a few things node operators must attend to for this upgrade. Check with your staking provider for assurance their systems are ready to go.
-
-Learn more about [The Merge](/upgrades/merge/)
+ When you stake 32 ETH with a SaaS provider, that ETH is still deposited to the official staking deposit contract. As such, SaaS stakers are currently limited by the same withdrawal restrictions as solo stakers. This means that staking your ETH is currently a one-way deposit. This will be the case until the Shanghai upgrade.
diff --git a/src/content/staking/solo/index.md b/src/content/staking/solo/index.md
index 4f64ba0b2e0..19de7421f97 100644
--- a/src/content/staking/solo/index.md
+++ b/src/content/staking/solo/index.md
@@ -9,7 +9,7 @@ image: ../../../assets/staking/leslie-solo.png
alt: Leslie the rhino on her own computer chip.
sidebarDepth: 2
summaryPoints:
- - Receive maximum rewards directly from the protocol (including unburnt fees after The Merge) for keeping your validator properly functioning and online
+ - Receive maximum rewards directly from the protocol for keeping your validator properly functioning and online
- Run home hardware and personally add to the security and decentralization of the Ethereum network
- Remove trust, and never give up control of the keys to your funds
---
@@ -58,7 +58,7 @@ As much as we wish that solo staking was accessible and risk free to everyone, t
- Withdrawing staked ETH or rewards from a validator balance is not yet supported. Support for withdrawals are planned for the Shanghai upgrade following The Merge. You should anticipate your ETH being locked for at least one-to-two years. After the Shanghai upgrade you will be able to freely withdraw portions or all of your stake if you wish.
+ Withdrawing staked ETH or rewards from a validator balance is not yet supported. Support for withdrawals are planned for the upcoming Shanghai upgrade. You should anticipate your ETH being locked for at least one-to-two years. After the Shanghai upgrade you will be able to freely withdraw portions or all of your stake if you wish.
Hardware occasionally fails, network connections error out, and client software occasionally needs upgrading. Node maintenance is inevitable and will occasionally require your attention. You'll want to be sure you stay aware of any anticipated network upgrades, or other critical client upgrades.
@@ -89,10 +89,6 @@ The Staking Launchpad is an open source application that will help you become a
-
-Note for existing stakers: The Merge is approaching, which brings a few changes since staking was launched. Make sure you're prepared with the Merge readiness checklist over on the Staking Launchpad.
-
-
## What to consider with node and client setup tools {#node-tool-considerations}
There are a growing number of tools and services to help you solo stake your ETH, but each come with different risks and benefits.
@@ -130,7 +126,9 @@ Have a suggestion for a staking tool we missed? Check out our [product listing p
These are a few of the most common questions about staking that are worth knowing about.
-A validator is a virtual entity that lives on the Beacon Chain and participates in the consensus of the Ethereum protocol. Validators are represented by a balance, public key, and other properties. A validator client is the software that acts on behalf of the validator by holding and using its private key. A single validator client can hold many key pairs, controlling many validators.
+
+A _validator_ is a virtual entity that lives on Ethereum and participates in the consensus of the Ethereum protocol. Validators are represented by a balance, public key, and other properties. A _validator client_ is the software that acts on behalf of the validator by holding and using its private key. A single validator client can hold many key pairs, controlling many validators.
+
@@ -180,18 +178,6 @@ Offline penalties are proportional to how many others are offline at the same ti
More on rewards and penalties
-
-Stakers currently running a consensus layer client (Beacon Chain) will also be required to run an execution layer client after The Merge. The new Engine API will be used to interface between the two layers, requiring a JWT secret. If you currently run a Beacon Chain without an execution layer client, you will need to sync the execution layer before The Merge to stay in sync with the network.
-
-The Merge will also bring unburnt transaction fees to validators. These fees do not accumulate in the balance associated with the validator keys but instead can be directed to a regular Ethereum address of your choice. To receive your tips (priority fees) from proposed blocks, you should update your client settings with the address you want your tips sent to.
-
-Links to individual client documentation and additional information can be found on the Merge readiness checklist over on the Launchpad.
-
-
-Merge readiness checklist
-
-
-
## Further reading {#further-reading}
- [Ethereum's Client Diversity Problem](https://hackernoon.com/ethereums-client-diversity-problem) - _@emmanuelawosika 2022_
diff --git a/src/content/upgrades/beacon-chain/index.md b/src/content/upgrades/beacon-chain/index.md
index 463d0d40881..feb057438c0 100644
--- a/src/content/upgrades/beacon-chain/index.md
+++ b/src/content/upgrades/beacon-chain/index.md
@@ -5,53 +5,44 @@ lang: en
template: upgrade
sidebar: true
image: ../../../assets/upgrades/core.png
-summaryPoint1: The Beacon Chain doesn't change anything about the Ethereum we use today.
-summaryPoint2: It introduced proof-of-stake to the Ethereum ecosystem.
-summaryPoint3: It will coordinate the network, serving as the consensus layer.
-summaryPoint4: It is an essential precursor to upcoming scaling upgrades, such as sharding.
+summaryPoint1: The Beacon Chain introduced proof-of-stake to the Ethereum ecosystem.
+summaryPoint2: It was merged with the original Ethereum proof-of-work chain in September 2022.
+summaryPoint3: The Beacon Chain introduced the consensus logic and block gossip protocol which now secures Ethereum.
---
- The Beacon Chain shipped on December 1, 2020. To learn more, explore the data. If you want to help validate the chain, you can stake your ETH.
+ The Beacon Chain shipped on December 1, 2020, and formalized proof-of-stake as Ethereum's consensus mechanism with The Merge upgrade on September 15, 2022.
-## What does the Beacon Chain do? {#what-does-the-beacon-chain-do}
+## What was the Beacon Chain? {#what-is-the-beacon-chain}
-The Beacon Chain is a ledger of accounts that conducts and coordinates the network of [stakers](/staking/). It isn't quite like the [Ethereum Mainnet](/glossary/#mainnet) of today. It does not process transactions or handle smart contract interactions.
+The Beacon Chain was the name of the original proof-of-stake blockchain that was launched in 2020. It was created to ensure the proof-of-stake consensus logic was sound and sustainable before enabling it on Ethereum Mainnet. Therefore, it ran alongside the original proof-of-work Ethereum. Switching off proof-of-work and switching on proof-of-stake on Ethereum required instructing the Beacon Chain to accept transactions from the original Ethereum chain, bundle them into blocks and then organize them into a blockchain using a proof-of-stake based consensus mechanism. At the same moment, the original Ethereum clients turned off their mining, block propagation and consensus logic, handing that all over to the Beacon Chain. This event was known as [The Merge](/upgrades/merge/). Once The Merge happened, there were no longer two blockchains; there was just one proof-of-stake Ethereum chain.
-It is a new consensus engine (or "consensus layer") that will soon take the place of proof-of-work mining, bringing many significant improvements with it.
+## What did the Beacon Chain do? {#what-does-the-beacon-chain-do}
-The Beacon Chain's role will change over time, but it's a foundational component for [the secure, environmentally friendly and scalable Ethereum we’re working towards](/upgrades/vision/).
+The Beacon Chain was the name given to a ledger of accounts that conducted and coordinated the network of Ethereum [stakers](/staking/) before those stakers started validating real Ethereum transactions. It did not process transactions or handle smart contract interactions.
+
+It introduced the consensus engine (or "consensus layer") that took the place of proof-of-work mining on Ethereum and brought many significant improvements with it.
+
+The Beacon Chain was a foundational component for [the secure, environmentally friendly and scalable Ethereum we have now](/upgrades/vision/).
## Beacon Chain impact {#beacon-chain-features}
### Introducing staking {#introducing-staking}
-The Beacon Chain introduced [proof-of-stake](/developers/docs/consensus-mechanisms/pos/) to Ethereum. This is a new way for you to help keep Ethereum secure. Think of it like a public good that will make Ethereum healthier and earn you more ETH in the process. In practice, staking involves you staking ETH in order to activate validator software. As a staker, you'll run node software that processes transactions and creates new blocks in the chain.
+The Beacon Chain introduced [proof-of-stake](/developers/docs/consensus-mechanisms/pos/) to Ethereum. This keeps Ethereum secure and earns validators more ETH in the process. In practice, staking involves staking ETH in order to activate validator software. As a staker, you run the software that creates and validates new blocks in the chain.
-Staking serves a similar purpose to [mining](/developers/docs/mining/), but is different in many ways. Mining requires large up-front expenditures in the form of powerful hardware and energy consumption, resulting in economies of scale, and promoting centralization. Mining also does not come with any requirement to lock up assets as collateral, limiting the protocol's ability to punish bad actors after an attack.
+Staking serves a similar purpose that [mining](/developers/docs/mining/) used to, but is different in many ways. Mining required large up-front expenditures in the form of powerful hardware and energy consumption, resulting in economies of scale, and promoting centralization. Mining also did not come with any requirement to lock up assets as collateral, limiting the protocol's ability to punish bad actors after an attack.
-The transition to proof-of-stake will make Ethereum significantly more secure and decentralized by comparison. The more people that participate in the network, the more decentralized and safe from attacks it becomes.
+The transition to proof-of-stake made Ethereum significantly more secure and decentralized by comparison to proof-of-work. The more people that participate in the network, the more decentralized and safe from attacks it becomes.
If you're interested in becoming a validator and helping secure the Ethereum, learn more about staking.
-### The Merge and the end of mining {#the-merge}
-
-While the Beacon Chain (or "consensus layer") is already live, it has existed as a separate chain from Mainnet (or the "execution layer") since its genesis. The plan is to swap out the current proof-of-work algorithm on the execution layer today and replace it with the proof-of-stake consensus protocol that the Beacon Chain provides.
-
-This process is known as **The Merge**, as it will 'merge' the new consensus layer with the existing execution layer and stop the use of mining.
-
-The Merge will have an immediate and profound impact on the carbon footprint of the Ethereum network. It also sets the stage for future scalability upgrades such as sharding.
-
-[Learn more about Ethereum energy consumption](/energy-consumption/)
-
-[Learn more about The Merge](/upgrades/merge/)
-
### Setting up for sharding {#setting-up-for-sharding}
-After Mainnet merges with the Beacon Chain, the next major upgrade will introduce sharding to the network.
+Since the Beacon Chain merged with the original Ethereum Mainnet, the Ethereum community started looking to scaling the network.
Proof-of-stake has the advantage of having a registry of all approved block producers at any given time, each with ETH at stake. This registry sets the stage for the ability to divide and conquer but reliably split up specific network responsibilities.
@@ -65,7 +56,7 @@ The Ethereum upgrades are all somewhat interrelated. So let’s recap how the Be
### Beacon Chain and The Merge {#merge-and-beacon-chain}
-The Beacon Chain, at first, will exist separately to the Ethereum Mainnet we use today. But eventually they will be connected. The plan is to "merge" Mainnet into the proof-of-stake system that's controlled and coordinated by the Beacon Chain.
+At first, The Beacon Chain existed separately from Ethereum Mainnet, but they were merged in 2022.
The Merge
@@ -73,14 +64,13 @@ The Beacon Chain, at first, will exist separately to the Ethereum Mainnet we use
### Shards and the Beacon Chain {#shards-and-beacon-chain}
-Sharding can only safely enter the Ethereum ecosystem with a proof-of-stake consensus mechanism in place. The Beacon Chain introduced staking, which when 'merged' with Mainnet will pave the way for sharding to help further scale Ethereum.
+Sharding can only safely enter the Ethereum ecosystem with a proof-of-stake consensus mechanism in place. The Beacon Chain introduced staking, which 'merged' with Mainnet, paving the way for sharding to help further scale Ethereum.
Shard chains
-
-
-## Interact with the Beacon Chain {#interact-with-beacon-chain}
+## Further Reading
-
+- [More on Ethereum's future upgrades](/upgrades/vision)
+- [More of proof-of-stake](/develoeprs/docs/consensus-mechanisms/pos)
diff --git a/src/content/upgrades/merge/index.md b/src/content/upgrades/merge/index.md
index aa82adb1506..8c1291eee83 100644
--- a/src/content/upgrades/merge/index.md
+++ b/src/content/upgrades/merge/index.md
@@ -1,63 +1,53 @@
---
title: The Merge
-description: Learn about The Merge - when Mainnet Ethereum joins the Beacon Chain coordinated proof-of-stake system.
+description: Learn about The Merge - when Mainnet Ethereum adopted proof-of-stake.
lang: en
template: upgrade
sidebar: true
image: ../../../assets/upgrades/merge.png
-summaryPoint1: Soon, the current Ethereum Mainnet will merge with the Beacon Chain proof-of-stake system.
-summaryPoint2: This will mark the end of proof-of-work for Ethereum, and the full transition to proof-of-stake.
-summaryPoint3: This sets the stage for future scaling upgrades including sharding.
-summaryPoint4: The Merge will reduce Ethereum's energy consumption by ~99.95%.
+summaryPoint1: Ethereum Mainnet uses proof-of-stake, but this wasn't always the case.
+summaryPoint2: The upgrade from the original proof-of-work mechanism to proof-of-stake was called The Merge.
+summaryPoint3: The Merge refers to the original Ethereum Mainnet merging with a separate proof-of-stake blockchain called the Beacon Chain, now existing as one chain.
+summaryPoint4: The Merge reduced Ethereum's energy consumption by ~99.95%.
---
-
-The Merge is the most significant upgrade in the history of Ethereum. Extensive testing and bug bounties were undertaken to ensure a safe transition to proof-of-stake.
-
-This process is in its final stages. Now that the testnets have undergone The Merge, [The Merge has been announced on Mainnet](https://blog.ethereum.org/2022/08/24/mainnet-merge-announcement).
+
+ The Merge was executed on September 15, 2022. This completed Ethereum's transition to proof-of-stake consensus, officially deprecating proof-of-work and reducing energy consumption by ~99.95%.
-## What is The Merge? {#what-is-the-merge}
-
-
+## What was The Merge? {#what-is-the-merge}
-The Merge represents the joining of the existing execution layer of Ethereum (the Mainnet we use today) with its new proof-of-stake consensus layer, the Beacon Chain. It eliminates the need for energy-intensive mining and instead secures the network using staked ETH. A truly exciting step in realizing the Ethereum vision – more scalability, security, and sustainability.
+The Merge was the joining of the original execution layer of Ethereum (the Mainnet that has existed since [genesis](/history/#frontier)) with its new proof-of-stake consensus layer, the Beacon Chain. It eliminated the need for energy-intensive mining and instead enabled the the network to be secured using staked ETH. It was a truly exciting step in realizing the Ethereum vision—more scalability, security, and sustainability.
-It's important to remember that initially, the [Beacon Chain](/upgrades/beacon-chain/) shipped separately from [Mainnet](/glossary/#mainnet). Ethereum Mainnet - with all its accounts, balances, smart contracts, and blockchain state - continues to be secured by [proof-of-work](/developers/docs/consensus-mechanisms/pow/), even while the Beacon Chain runs in parallel using [proof-of-stake](/developers/docs/consensus-mechanisms/pos/). The approaching Merge is when these two systems finally come together, and proof-of-work is replaced permanently by proof-of-stake.
+Initially, the [Beacon Chain](/upgrades/beacon-chain/) shipped separately from [Mainnet](/glossary/#mainnet). Ethereum Mainnet - with all it's accounts, balances, smart contracts, and blockchain state - continued to be secured by [proof-of-work](/developers/docs/consensus-mechanisms/pow/), even while the Beacon Chain ran in parallel using [proof-of-stake](/developers/docs/consensus-mechanisms/pos/). The Merge was when these two systems finally came together, and proof-of-work was permanently replaced by proof-of-stake.
-Let's consider an analogy. Imagine Ethereum is a spaceship that isn't quite ready for an interstellar voyage. With the Beacon Chain, the community has built a new engine and a hardened hull. After significant testing, it's almost time to hot-swap the new engine for the old mid-flight. This will merge the new, more efficient engine into the existing ship, ready to put in some serious lightyears and take on the universe.
+Imagine Ethereum is a spaceship that launched before it was quite ready for an interstellar voyage. With the Beacon Chain, the community built a new engine and a hardened hull. After significant testing, it became time to hot-swap the new engine for the old one mid-flight. This merged the new, more efficient engine into the existing ship enabling it to put in some serious lightyears and take on the universe.
## Merging with Mainnet {#merging-with-mainnet}
-Since [genesis](/history/#frontier), proof-of-work has secured Mainnet. This is the Ethereum blockchain we're all used to—it contains every transaction, smart contract, and balance since it began in July 2015.
+Proof-of-work secured Ethereum Mainnet from genesis until The Merge. This allowed the Ethereum blockchain we're all used to to come into existence in July 2015 with all its familiar features—transactions, smart contracts, accounts, etc.
-Throughout Ethereum's history, developers have been hard at work preparing for an eventual transition away from proof-of-work to proof-of-stake. On December 1, 2020, the Beacon Chain was created, which has since existed as a separate blockchain to Mainnet, running in parallel.
+Throughout Ethereum's history, developers prepared for an eventual transition away from proof-of-work to proof-of-stake. On December 1, 2020, the Beacon Chain was created as a separate blockchain to Mainnet, running in parallel.
-The Beacon Chain has not been processing Mainnet transactions. Instead, it has been reaching consensus on its own state by agreeing on active validators and their account balances. After extensive testing, the Beacon Chain's time to reach consensus on more is rapidly approaching. After The Merge, the Beacon Chain will be the consensus engine for all network data, including execution layer transactions and account balances.
+The Beacon Chain was not originally processing Mainnet transactions. Instead, it was reaching consensus on its own state by agreeing on active validators and their account balances. After extensive testing, it became time for the Beacon Chain to reach consensus on real world data. After The Merge, the Beacon Chain became the consensus engine for all network data, including execution layer transactions and account balances.
-The Merge represents the official switch to using the Beacon Chain as the engine of block production. Mining will no longer be the means of producing valid blocks. Instead, the proof-of-stake validators assume this role and will be responsible for processing the validity of all transactions and proposing blocks.
+The Merge represented the official switch to using the Beacon Chain as the engine of block production. Mining is no longer the means of producing valid blocks. Instead, the proof-of-stake validators have adopted this role and are now responsible for processing the validity of all transactions and proposing blocks.
-No history is lost. As Mainnet gets merged with the Beacon Chain, it will also merge the entire transactional history of Ethereum. You don't need to do anything. Your funds are safe.
+No history was lost in The Merge. As Mainnet merged with the Beacon Chain, it also merged the entire transactional history of Ethereum.
-This transition to proof-of-stake will come with some changes to the way ether is supplied. Learn more about ether issuance before and after The Merge.
+This transition to proof-of-stake changed the way ether is issued. Learn more about ether issuance before and after The Merge.
-## What do I need to do to get ready? {#preparing-for-the-merge}
-
-The Merge is one of the most significant and anticipated upgrades in the history of Ethereum, and although in the long-term its impact will be felt by everyone, in the near-term some folks will need to take action to be fully prepared.
-
### Users and holders {#users-holders}
-**You do not need to do anything to protect your funds entering The Merge.**
-
-_This bears repeating_: As a user or holder of ETH or any other digital asset on Ethereum, as well as non-node-operating stakers, **you do not need to do anything with your funds or wallet before The Merge.**
+**The Merge did not change anything for holders/users.**
-Despite swapping out proof-of-work, the entire history of Ethereum since genesis remains intact and unaltered after the transition to proof-of-stake. Any funds held in your wallet before The Merge will still be accessible after The Merge. **No action is required to upgrade on your part.**
+_This bears repeating_: As a user or holder of ETH or any other digital asset on Ethereum, as well as non-node-operating stakers, **you do not need to do anything with your funds or wallet to account for The Merge.** ETH is just ETH. There is no such thing as "old ETH"/"new ETH" or "ETH1"/"ETH2" and wallets work exactly the same after The Merge as they did before—people telling you otherwise are likely scammers.
-As we approach The Merge of Ethereum Mainnet, **you should be on high alert for scams trying to take advantage of users during this transition.** Do not send your ETH anywhere in an attempt to "upgrade to ETH2." There is no "ETH2" token, and there is nothing more you need to do for your funds to remain safe.
+Despite swapping out proof-of-work, the entire history of Ethereum since genesis remained intact and unaltered by the transition to proof-of-stake. Any funds held in your wallet before The Merge will are still accessible after The Merge. **No action is required to upgrade on your part.**
[More on Ethereum security](/security/#eth2-token-scam)
@@ -65,49 +55,44 @@ As we approach The Merge of Ethereum Mainnet, **you should be on high alert for
Key action items include:
-1. Run _both_ a consensus layer client and an execution layer client; third-party endpoints to obtain execution data will be unavailable after The Merge.
-1. Authenticate both execution layer and consensus layer clients with a shared JWT secret so they can securely communicate.
-1. Set a `fee recipient` address to receive your earned transaction fee tips/MEV.
+1. Run _both_ a consensus client and an execution client; third-party endpoints to obtain execution data no longer work since The Merge.
+2. Authenticate both execution and consensus clients with a shared JWT secret so they can securely communicate.
+3. Set a `fee recipient` address to receive your earned transaction fee tips/MEV.
-Not completing the first two items above items will result in your node being seen as "offline" after The Merge until both layers are synced and authenticated.
+Not completing the first two items above items will result in your node being seen as "offline" until both layers are synced and authenticated.
Not setting a `fee recipient` will still allow your validator to behave as usual, but you will miss out on unburnt fee tips and any MEV you would have otherwise earned in blocks your validator proposes.
-
-For more detailed information and a summary of links to client resources, stakers are encouraged to check out the [Merge Readiness Checklist](https://launchpad.ethereum.org/en/merge-readiness/) over on the Staking Launchpad to make sure you're fully prepared for The Merge.
-
-Note for stakers using [SaaS](/staking/saas/) or [staking pools](/staking/pools/): There is nothing you need to do to prepare for The Merge. [More below on staying safe.](#users-holders)
-You probably are already running an execution layer client, such as Geth, Erigon, Besu or Nethermind. Up until The Merge, an execution layer client was enough to receive, properly validate, and propagate blocks being gossiped by the network. _After The Merge_, the validity of transactions contained within an execution payload will also depend on the validity of the "consensus block" it is contained within.
+Up until The Merge, an execution client (such as Geth, Erigon, Besu or Nethermind) was enough to receive, properly validate, and propagate blocks being gossiped by the network. _After The Merge_, the validity of transactions contained within an execution payload now also depends on the validity of the "consensus block" it is contained within.
-As a result, a full Ethereum node after The Merge requires both an execution layer client and a consensus layer client. These two clients work together using a new Engine API. The Engine API requires authentication using a JWT secret, which is provided to both clients allowing secure communication.
+As a result, a full Ethereum node now requires both an execution client and a consensus client. These two clients work together using a new Engine API. The Engine API requires authentication using a JWT secret, which is provided to both clients allowing secure communication.
Key action items include:
-- Install a consensus layer client in addition to an execution layer client
+- Install a consensus client in addition to an execution client
- Authenticate execution and consensus clients with a shared JWT secret so they can securely communicate with one another.
-Not completing the above items in time for The Merge will result in your node appearing to be "offline" until both layers are synced and authenticated.
+Not completing the above items will result in your node appearing to be "offline" until both layers are synced and authenticated.
-Node operators can also check out the [Merge Readiness Checklist](https://launchpad.ethereum.org/en/merge-readiness/) on the Staking Launchpad for more information, as many of the details apply to all node operators.
-The Merge comes with changes to consensus, which also includes changes related to:
+The Merge came with changes to consensus, which also includes changes related to:
- block structure
- slot/block timing
@@ -118,21 +103,19 @@ The Merge comes with changes to consensus, which also includes changes related t
For more information, check out this blog post by Tim Beiko on [How The Merge Impacts Ethereum’s Application Layer](https://blog.ethereum.org/2021/11/29/how-the-merge-impacts-app-layer/).
-## What date is The Merge? {#wen-merge}
-
-The Merge is happening on 14/15th September. The precise timing depends upon how the network hash rate develops and it can be monitored at [bordel.wtf](https://bordel.wtf). The Merge will be triggered when the network passes a threshold accumulated difficulty, known as the TTD (terminal total difficulty). You can track total difficulty milestones using the [Nethermind TTD bot](https://explorer.forta.network/bot/0x5c2f5e0854ff24b425efc3a860953ee2923d9b0bc73ea86acd29d45d588e7bdc).
+## The Merge and energy consumption {#merge-and-energy}
-## After The Merge {#after-the-merge}
+The Merge marked the end of proof-of-work for Ethereum and start the era of a more sustainable, eco-friendly Ethereum. Ethereum's energy consumption dropped by an estimated 99.95%, making Ethereum a green blockchain. Learn more about [Ethereum energy consumption](/energy-consumption/).
-This will signal the end of proof-of-work for Ethereum and start the era of a more sustainable, eco-friendly Ethereum. Learn more about [Ethereum energy consumption](/energy-consumption/).
+## The Merge and scaling {#merge-and-scaling}
-This will also set the stage for further scalability upgrades not possible under proof-of-work, bringing Ethereum one step closer to achieving the full scale, security and sustainability outlined in its [Ethereum vision](/upgrades/vision/).
+The Merge also set the stage for further scalability upgrades not possible under proof-of-work, bringing Ethereum one step closer to achieving the full scale, security and sustainability outlined in its [Ethereum vision](/upgrades/vision/).
## Misconceptions about The Merge {#misconceptions}
+contentPreview="False. Anyone is free to sync their own self-verified copy of Ethereum (i.e. run a node). No ETH is required—not before The Merge, not after The Merge, not ever.">
There are two types of Ethereum nodes: nodes that can propose blocks and nodes that don't.
Nodes that propose blocks are only a small number of the total nodes on Ethereum. This category includes mining nodes under proof-of-work (PoW) and validator nodes under proof-of-stake (PoS). This category requires committing economic resources (such as GPU hash power in proof-of-work or staked ETH in proof-of-stake) in exchange for the ability to occasionally propose the next block and earn protocol rewards.
@@ -148,41 +131,38 @@ The ability for anyone to run their own node is _absolutely essential_ to mainta
-Gas fees are a product of network demand relative to the capacity of the network. The Merge deprecates the use of proof-of-work, transitioning to proof-of-stake for consensus, but does not significantly change any parameters that directly influence network capacity or throughput.
+title="Misconception: "The Merge failed to reduced gas fees.""
+contentPreview="False. The Merge was a change of consensus mechanism, not an expansion of network capacity, and was never intended to lower gas fees.">
+Gas fees are a product of network demand relative to the capacity of the network. The Merge deprecated the use of proof-of-work, transitioning to proof-of-stake for consensus, but did not significantly change any parameters that directly influence network capacity or throughput.
With a [rollup-centric roadmap](https://ethereum-magicians.org/t/a-rollup-centric-ethereum-roadmap/4698), efforts are being focused on scaling user activity at [layer 2](/layer-2/), while enabling layer 1 Mainnet as a secure decentralized settlement layer optimized for rollup data storage to help make rollup transactions exponentially cheaper. The transition to proof-of-stake is a critical precursor to realizing this. [More on gas and fees.](/developers/docs/gas/)
+title="Misconception: "Transactions were accelerated substantially by The Merge.""
+contentPreview="False. Though some slight changes exist, transaction speed is mostly the same on layer 1 now as it was before The Merge.">
A transaction's "speed" can be measured in a few ways, including time to be included in a block and time to finalization. Both of these changes slightly, but not in a way that users will notice.
-Historically, on proof-of-work, the target was to have a new block every ~13.3 seconds. On the Beacon Chain, slots occur precisely every 12 seconds, each of which is an opportunity for a validator to publish a block. Most slots have blocks, but not necessarily all (i.e. a validator is offline). On proof-of-stake blocks will be produced ~10% more frequently than on proof-of-work. This is a fairly insignificant change and is unlikely to be noticed by users.
+Historically, on proof-of-work, the target was to have a new block every ~13.3 seconds. Under proof-of-stake, slots occur precisely every 12 seconds, each of which is an opportunity for a validator to publish a block. Most slots have blocks, but not necessarily all (i.e. a validator is offline). In proof-of-stake, blocks are produced ~10% more frequently than on proof-of-work. This was a fairly insignificant change and is unlikely to be noticed by users.
-Proof-of-stake introduces the transaction finality concept that did not previously exist. On proof-of-work, the ability to reverse a block gets exponentially more difficult with every passing block mined on top of a transaction, but it never quite reaches zero. Under proof-of-stake, blocks are bundled into epochs (6.4 minute spans of time containing 32 chances for blocks) which validators vote on. When an epoch ends, validators vote on whether to consider the epoch 'justified'. If validators agree to justify the epoch, it gets finalized in the next epoch. Undoing finalized transactions is economically unviable as it would require obtaining and burning over one-third of the total staked ETH.
+Proof-of-stake introduced the transaction finality concept that did not previously exist. In proof-of-work, the ability to reverse a block gets exponentially more difficult with every passing block mined on top of a transaction, but it never quite reaches zero. Under proof-of-stake, blocks are bundled into epochs (6.4 minute spans of time containing 32 chances for blocks) which validators vote on. When an epoch ends, validators vote on whether to consider the epoch 'justified'. If validators agree to justify the epoch, it gets finalized in the next epoch. Undoing finalized transactions is economically unviable as it would require obtaining and burning over one-third of the total staked ETH.
-Many dapps require a number of proof-of-work block confirmations that take a period of time on par with how long proof-of-stake finality takes. Finality can offer additional security guarantees, but will not significantly speed up transactions.
-Staked ETH, staking rewards to date, and newly issued ETH immediately after The Merge will still be locked on the Beacon Chain without the ability to withdraw.
-
-Withdrawals are planned for the Shanghai upgrade, the next major upgrade following The Merge. This means that newly issued ETH, though accumulating on the Beacon Chain, will remain locked and illiquid for at least 6-12 months following The Merge.
+Staked ETH and staking rewards continue to be locked without the ability to withdraw. Withdrawals are planned for the upcoming Shanghai upgrade.
-This may seem counterintuitive to the above note that withdrawals are not enabled til the Shanghai upgrade, but validators WILL have immediate access to the fee rewards/MEV earned during block proposals.
+title="Misconception: "Validators will not receive any liquid ETH rewards til the Shanghai upgrade when withdrawals are enabled.""
+contentPreview="False. Fee tips/MEV are credited to a non-staking account controlled by the validator, available immediately.">
+This may seem counterintuitive to the above note that withdrawals are not enabled til the Shanghai upgrade, but validators DO have immediate access to the fee rewards/MEV earned during block proposals.
-The protocol issues ETH as a reward to validators for contributing to consensus. This Beacon Chain accounts for the newly issued ETH, where a validator has a unique address that holds its staked ETH and protocol rewards. This ETH is locked until Shanghai.
+The protocol issues ETH as a reward to validators for contributing to consensus. The consensus layer accounts for the newly issued ETH, where a validator has a unique address that holds its staked ETH and protocol rewards. This ETH is locked until Shanghai.
-ETH on the execution layer (Ethereum Mainnet as we know it today) is accounted for separately from the consensus layer. When users execute transactions on Ethereum Mainnet, ETH must be paid to cover the gas, including a tip to the validator. This ETH is already on the execution layer, is NOT being newly issued by the protocol, and is available to the validator immediately (given a proper `fee recipient` address is provided to the client software).
+ETH on the execution layer is accounted for separately from the consensus layer. When users execute transactions on Ethereum Mainnet, ETH must be paid to cover the gas, including a tip to the validator. This ETH is already on the execution layer, is NOT being newly issued by the protocol, and is available to the validator immediately (given a proper `fee recipient` address is provided to the client software).
-
-The APR for stakers is expected to increase post-merge. To understand by how much, it is important to recognize where this increase in APR is coming from. This does not come from an increase in protocol ETH issuance (ETH issuance after The Merge is decreasing by ~90%), but is instead a reallocation of transaction fees that will start going to validators instead of miners.
-
-This will be a new separate source of revenue for validators when they propose blocks. As you can imagine, the amount of fees a validator receives is proportional to network activity at the time of their proposed block. The more fees being paid by users, the more fees validators will receive.
-
-Looking at recent blockchain activity, approximately 10% of all gas fees being paid are currently going to miners in the form of a tip, while the rest is burnt. Outdated predictions estimated this percentage to be much higher, and was calculated when network usage was at all time highs. Extrapolating the 10% number to average recent network activity, it is estimated that the APR for staking will increase to ~7%, approximately 50% higher than the base issuance APR (as of June 2022).
-
-
-
-An immense amount of work has been put into making sure the transition to proof-of-stake does not disrupt the network or its users.
-
-The Merge is like changing an engine on a rocketship mid-flight and is designed to be performed without needing to pause anything during the switch. The Merge will be triggered by **[terminal total difficulty (TTD)](/glossary/#terminal-total-difficult)**, which is a cumulative measure of the total mining power that has gone into building the chain. When the time comes, and this criterion is met, blocks will go from being built using proof-of-work in one block to being built by proof-of-stake in the next.
-
-Ethereum does not have downtime.
-
-
## What happened to 'Eth2'? {#eth2}
-The term 'Eth2' has been deprecated as we approach The Merge.
-
-After merging 'Eth1' and 'Eth2' into a single chain, there will no longer be two distinct Ethereum networks; there will only be Ethereum.
+The term 'Eth2' has been deprecated. After merging 'Eth1' and 'Eth2' into a single chain, there is no longer any need to
+distinguish between two Ethereum networks; there is just Ethereum.
To limit confusion, the community has updated these terms:
@@ -236,9 +195,9 @@ The Ethereum upgrades are all somewhat interrelated. So let’s recap how The Me
### The Merge and the Beacon Chain {#merge-and-beacon-chain}
-The Merge represents the formal adoption of the Beacon Chain as the new consensus layer to the current Mainnet execution layer. Once The Merge happens, validators will be assigned to secure Ethereum Mainnet, and mining on [proof-of-work](/developers/docs/consensus-mechanisms/pow/) will no longer be a valid means of block production.
+The Merge represents the formal adoption of the Beacon Chain as the new consensus layer to the original Mainnet execution layer. Since The Merge, validators are assigned to secure Ethereum Mainnet, and mining on [proof-of-work](/developers/docs/consensus-mechanisms/pow/) is no longer a valid means of block production.
-Blocks will instead be proposed by validating nodes that have ether staked for the right to participate in consensus. These upgrades set the stage for future scalability upgrades, including sharding.
+Blocks are instead proposed by validating nodes that have staked ETH in return for the right to participate in consensus. These upgrades set the stage for future scalability upgrades, including sharding.
The Beacon Chain
@@ -246,13 +205,13 @@ Blocks will instead be proposed by validating nodes that have ether staked for t
### The Merge and the Shanghai upgrade {#merge-and-shanghai}
-In order to simplify and maximize focus on a successful transition to proof-of-stake, The Merge upgrade will not include certain anticipated features such as the ability to withdraw staked ETH. The Shanghai upgrade is planned to follow The Merge, which will enable the ability for stakers to withdraw.
+In order to simplify and maximize focus on a successful transition to proof-of-stake, The Merge upgrade did not include certain anticipated features such as the ability to withdraw staked ETH. The Shanghai upgrade is planned to follow The Merge, which will enable the ability for stakers to withdraw.
Stay up-to-date with the [Shanghai upgrade planning issue on GitHub](https://github.com/ethereum/pm/issues/450), or the [EF Research and Development Blog](https://blog.ethereum.org/category/research-and-development/). For those curious, learn more about [What Happens After The Merge](https://youtu.be/7ggwLccuN5s?t=101), presented by Vitalik at the April 2021 ETHGlobal event.
### The Merge and sharding {#merge-and-data-sharding}
-Originally, the plan was to work on sharding before The Merge to address scalability. However, with the boom of [layer 2 scaling solutions](/layer-2/), the priority has shifted to swapping proof-of-work to proof-of-stake via The Merge.
+Originally, the plan was to work on sharding before The Merge to address scalability. However, with the boom of [layer 2 scaling solutions](/layer-2/), the priority shifted to swapping proof-of-work to proof-of-stake first.
Plans for sharding are rapidly evolving, but given the rise and success of layer 2 technologies to scale transaction execution, sharding plans have shifted to finding the most optimal way to distribute the burden of storing compressed calldata from rollup contracts, allowing for exponential growth in network capacity. This would not be possible without first transitioning to proof-of-stake.
diff --git a/src/content/upgrades/sharding/index.md b/src/content/upgrades/sharding/index.md
index 6279c07bc65..ab6fc5eb02a 100644
--- a/src/content/upgrades/sharding/index.md
+++ b/src/content/upgrades/sharding/index.md
@@ -8,11 +8,11 @@ image: ../../../assets/upgrades/newrings.png
summaryPoint1: Sharding is a multi-phase upgrade to improve Ethereum’s scalability and capacity.
summaryPoint2: Sharding provides secure distribution of data storage requirements, enabling rollups to be even cheaper, and making nodes easier to operate.
summaryPoint3: They enable layer 2 solutions to offer low transaction fees while leveraging the security of Ethereum.
-summaryPoint4: This upgrade is planned to follow The Merge of Mainnet with the Beacon Chain.
+summaryPoint4: This upgrade has become more of a focus since Ethereum moved to proof-of-stake.
---
- Sharding should ship sometime in 2023, depending on how quickly work progresses after The Merge. These shards will give Ethereum more capacity to store and access data, but they won’t be used for executing code.
+ Sharding could ship sometime in 2023. Shards will give Ethereum more capacity to store and access data, but they won’t be used for executing code.
## What is sharding? {#what-is-sharding}
@@ -31,31 +31,25 @@ Sharding is a good way to scale if you want to keep things decentralized as the
Sharding will eventually let you run Ethereum on a personal laptop or phone. So more people should be able to participate, or run [clients](/developers/docs/nodes-and-clients/), in a sharded Ethereum. This will increase security because the more decentralized the network, the smaller the attack surface area.
-With lower hardware requirements, sharding will make it easier to run [clients](/developers/docs/nodes-and-clients/) on your own, without relying on any intermediary services at all. And if you can, consider running multiple clients. This can help network health by further reducing points of failure. [Run a Beacon Chain client](/upgrades/get-involved/)
+With lower hardware requirements, sharding will make it easier to run [clients](/developers/docs/nodes-and-clients/) on your own, without relying on any intermediary services at all. And if you can, consider running multiple clients. This can help network health by further reducing points of failure.
- At first, you'll need to run a Mainnet (execution layer) client at the same time as your Beacon Chain (consensus later) client. The launchpad will walk you through the hardware requirements and process.
+ You'll need to run an execution client at the same time as your consensus client. The launchpad will walk you through the hardware requirements and process.
## Shard chains version 1: data availability {#data-availability}
Note: The plans for sharding have been evolving as more efficient paths to scaling have been developed. "Danksharding" is a new approach to sharding, which does not utilize the concept of shard "chains" but instead uses shard "blobs" to split up the data, along with "data availability sampling" to confirm all data has been made available. This change in plan solves the same original problem.
- Details below may be out of date with the latest development plans. While we update things, check out The Hitchhiker's Guide to the Ethereum for an excellent breakdown of Ethereum plans after The Merge.
+ Details below may be out of date with the latest development plans. While we update things, check out The Hitchhiker's Guide to the Ethereum for an excellent breakdown of Ethereum roadmap.
When the first shard chains are shipped they will just provide extra data to the network. They won’t handle transactions or smart contracts. But they’ll still offer incredible improvements to transactions per second when combined with rollups.
Rollups are a "layer 2" technology that exists today. They allow dapps to bundle or “roll up” transactions into a single transaction off-chain, generate a cryptographic proof and then submit it to the chain. This reduces the data needed for a transaction. Combine this with all the extra data availability provided by shards and you get 100,000 transactions per second.
-
- Given recent progress in layer 2 scaling solution research and development, this has prompted the prioritization of transitioning to proof-of-stake ahead of sharding. Sharding will be the focus following The Merge.
-
-[More on rollups](/developers/docs/scaling/#rollups)
-
-
## Shard chains version 2: code execution {#code-execution}
The plan was always to add extra functionality to shards, to make them more like the [Ethereum Mainnet](/glossary/#mainnet) today. This would allow them to store and execute code and handle transactions, as each shard would contain its unique set of smart contracts and account balances. Cross-shard communication would allow for transactions between shards.
@@ -92,25 +86,9 @@ This is still an active discussion point. We’ll update these pages once we kno
The Ethereum upgrades are all somewhat interrelated. So let’s recap how the shard chains relate the other upgrades.
-### Shards and the beacon chain {#shards-and-beacon-chain}
-
-The Beacon Chain contains all the logic for keeping shards secure and synced up. The Beacon Chain will coordinate the stakers in the network, assigning them to shards they need to work on. And it will also facilitate communication between shards by receiving and storing shard transaction data that is accessible by other shards. This will give shards a snapshot of Ethereum’s state to keep everything up-to-date.
-
-
- The Beacon Chain
-
-
-### Shards and The Merge {#shards-and-docking}
-
-By the time additional shards are added, Ethereum Mainnet will already be secured by the Beacon Chain using proof-of-stake. This enables a fertile Mainnet to build shard chains off of, powered by layer 2 solutions that supercharge the scalability.
-
-It remains to be seen whether Mainnet will exist as the only “smart” shard that can handle code execution – but either way, the decision to expand shards can be revisited as needed.
-
-
- The Merge
-
+### Shards and the Ethereum blockchain {#shards-and-blockchain}
-
+The logic for keeping shards secure and synced up is all integrated into the Ethereum clients that build the blockchain. Stakers in the network will be assigned to shards to work on. Shards will have access to snapshots of other shards so they can build a view of Ethereum’s state to keep everything up-to-date.
### Read more {#read-more}
diff --git a/src/data/community-events.json b/src/data/community-events.json
index daeca57a99d..2172e428bc0 100644
--- a/src/data/community-events.json
+++ b/src/data/community-events.json
@@ -530,7 +530,7 @@
"startDate": "2022-11-26",
"endDate": "2022-11-30"
},
- {
+ {
"title": "ETHBrno",
"to": "https://ethbrno.cz",
"sponsor": null,
@@ -539,7 +539,7 @@
"startDate": "2022-11-11",
"endDate": "2022-11-13"
},
- {
+ {
"title": "Web3SD",
"to": "http://web3.sd",
"sponsor": null,
diff --git a/src/data/community-meetups.json b/src/data/community-meetups.json
index 3763c3c441f..4032a244eae 100644
--- a/src/data/community-meetups.json
+++ b/src/data/community-meetups.json
@@ -293,6 +293,12 @@
"location": "Chicago",
"link": "https://www.meetup.com/Chicago-Ethereum-Meetup/"
},
+ {
+ "title": "Matos Cryptobar",
+ "emoji": ":sweden:",
+ "location": "Stockholm",
+ "link": "https://matos.club/"
+ },
{
"title": "Web3Dubai",
"emoji": ":uae:",
diff --git a/src/data/developer-docs-links.yaml b/src/data/developer-docs-links.yaml
index 870254e6060..e29740e4f52 100644
--- a/src/data/developer-docs-links.yaml
+++ b/src/data/developer-docs-links.yaml
@@ -77,6 +77,10 @@
to: /developers/docs/consensus-mechanisms/pos/weak-subjectivity/
- id: docs-nav-attestations
to: /developers/docs/consensus-mechanisms/pos/attestations
+ - id: docs-nav-rewards-and-penalties
+ to: /developers/docs/consensus-mechanisms/pos/rewards-and-penalties/
+ - id: docs-nav-keys
+ to: /developers/docs/consensus-mechanisms/pos/keys/
- id: docs-nav-ethereum-stack
path: /developers/docs/
items:
diff --git a/src/hooks/useConfetti.ts b/src/hooks/useConfetti.ts
new file mode 100644
index 00000000000..5975a8254f5
--- /dev/null
+++ b/src/hooks/useConfetti.ts
@@ -0,0 +1,15 @@
+import { useEffect } from "react"
+import { useReward } from "react-rewards"
+
+export const useConfetti = (elementId: string): void => {
+ const { reward: confetti } = useReward(elementId, "confetti", {
+ spread: 360,
+ elementCount: 42,
+ position: "absolute",
+ zIndex: 10,
+ lifetime: 420,
+ })
+ useEffect(() => {
+ confetti()
+ })
+}
diff --git a/src/hooks/useConsoleEasterEgg.ts b/src/hooks/useConsoleEasterEgg.ts
new file mode 100644
index 00000000000..6d826e30f7d
--- /dev/null
+++ b/src/hooks/useConsoleEasterEgg.ts
@@ -0,0 +1,17 @@
+import { useEffect } from "react"
+
+export const useConsoleEasterEgg = () => {
+ useEffect(() => {
+ console.log(`
+The Merge is complete.
+
+🐼🐼🐼🐼🐼🐼🐼🐼🐼🐼🐼🐼🐼🐼
+
+Welcome to a greener Ethereum.
+
+🌳🌳🌳🌳🌳🌳🌳🌳🌳🌳🌳🌳🌳🌳
+
+Come help us build it: https://ethereum.org/en/contributing
+ `)
+ })
+}
diff --git a/src/intl/de/common.json b/src/intl/de/common.json
index 9b0ffc129dc..9c8e9d39339 100644
--- a/src/intl/de/common.json
+++ b/src/intl/de/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Matcha-Logo",
"medalla-data-challenge": "Die Medalla-Datenherausforderung",
"merge": "Zusammenführen",
+ "merge-complete": "Die Fusion ist abgeschlossen! Willkommen in einem neuen, grüneren Ethereum!",
"more": "Mehr",
"more-info": "Mehr Info",
"nav-beginners": "Anfänger",
diff --git a/src/intl/el/common.json b/src/intl/el/common.json
index a4a470522b3..086b07a9908 100644
--- a/src/intl/el/common.json
+++ b/src/intl/el/common.json
@@ -166,6 +166,7 @@
"matcha-logo": "Λογότυπο Matcha",
"medalla-data-challenge": "Πρόκληση δεδομένων Medalla",
"merge": "Συγχώνευση",
+ "merge-complete": "Η Συγχώνευση ολοκληρώθηκε! Καλωσήρθατε σε ένα πιο πράσινο Ethereum.",
"more": "Περισσότερα",
"more-info": "Περισσότερες πληροφορίες",
"nav-beginners": "Αρχάριοι",
diff --git a/src/intl/en/common.json b/src/intl/en/common.json
index 59ea2af51c1..2b9a34ce567 100644
--- a/src/intl/en/common.json
+++ b/src/intl/en/common.json
@@ -190,6 +190,7 @@
"matcha-logo": "Matcha logo",
"medalla-data-challenge": "Medalla data challenge",
"merge": "Merge",
+ "merge-complete": "The Merge is complete! Welcome to a new greener Ethereum.",
"mission-and-vision": "Mission and vision",
"more": "More",
"more-info": "More info",
diff --git a/src/intl/en/page-developers-docs.json b/src/intl/en/page-developers-docs.json
index 8ac334ae02e..4ab1d0848ae 100644
--- a/src/intl/en/page-developers-docs.json
+++ b/src/intl/en/page-developers-docs.json
@@ -15,6 +15,7 @@
"docs-nav-gasper": "Gasper",
"docs-nav-weak-subjectivity": "Weak subjectivity",
"docs-nav-attestations": "Attestations",
+ "docs-nav-keys": "Keys",
"docs-nav-data-and-analytics": "Data and analytics",
"docs-nav-data-and-analytics-description": "How blockchain data is aggregated, organized and implemented into dapps",
"docs-nav-data-availability": "Data availability",
@@ -115,6 +116,7 @@
"docs-nav-data-structures-and-encoding-rlp": "Recursive-length prefix (RLP)",
"docs-nav-data-structures-and-encoding-patricia-merkle-trie": "Patricia Merkle Trie",
"docs-nav-data-structures-and-encoding-ssz": "Simple serialize (SSZ)",
+ "docs-nav-rewards-and-penalties": "PoS rewards and penalties",
"page-calltocontribute-desc-1": "If you're an expert on the topic and want to contribute, edit this page and sprinkle it with your wisdom.",
"page-calltocontribute-desc-2": "You'll be credited and you'll be helping the Ethereum community!",
"page-calltocontribute-desc-3": "Use this flexible",
diff --git a/src/intl/en/page-eth.json b/src/intl/en/page-eth.json
index 57a223f4d3b..2d2814f9560 100644
--- a/src/intl/en/page-eth.json
+++ b/src/intl/en/page-eth.json
@@ -16,13 +16,13 @@
"page-eth-flexible-amounts-desc": "ETH is divisible up to 18 decimal places so you don't have to buy 1 whole ETH. You can buy fractions at a time – as little as 0.000000000000000001 ETH if you want.",
"page-eth-fuels": "ETH fuels and secures Ethereum",
"page-eth-fuels-desc": "ETH is the lifeblood of Ethereum. When you send ETH or use an Ethereum application, you'll pay a fee in ETH to use the Ethereum network. This fee is an incentive for a block producer to process and verify what you're trying to do.",
- "page-eth-fuels-desc-2": "Currently, miners are like the record-keepers of Ethereum—they check and prove that no one is cheating, and perform work for the right to propose a block of transactions. Miners who do this work are also rewarded with small amounts of newly-issued ETH.",
- "page-eth-fuels-desc-3": "The work miners do keeps Ethereum secure and free of centralized control. In other words,",
- "page-eth-fuels-staking": "Soon, ETH will become even more important with staking. When you stake your ETH, you'll be able to help secure Ethereum and earn rewards. In this system, the threat of losing their ETH deters attackers.",
+ "page-eth-fuels-desc-2": "Validators are like the record-keepers of Ethereum—they check and prove that no one is cheating. They are randomly selected to propose a block of transactions. Validators who do this work are also rewarded with small amounts of newly-issued ETH.",
+ "page-eth-fuels-desc-3": "The work validators do, and the capital they stake, keeps Ethereum secure and free of centralized control.",
+ "page-eth-fuels-staking": "When you stake your ETH, you help secure Ethereum and earn rewards. In this system, the threat of losing ETH deters attackers.",
"page-eth-fuels-more-staking": "More on staking",
"page-eth-get-eth-btn": "Get ETH",
"page-eth-gov-tokens": "Governance tokens",
- "page-eth-gov-tokens-desc": "Tokens that represent voting power in decentralized organisations.",
+ "page-eth-gov-tokens-desc": "Tokens that represent voting power in decentralized organizations.",
"page-eth-has-value": "Why does ETH have value?",
"page-eth-has-value-desc": "ETH's valuable in different ways to different people.",
"page-eth-has-value-desc-2": "For users of Ethereum, ETH is valuable because it lets you pay transaction fees.",
diff --git a/src/intl/en/page-staking.json b/src/intl/en/page-staking.json
index 2a53954c247..9fac1442227 100644
--- a/src/intl/en/page-staking.json
+++ b/src/intl/en/page-staking.json
@@ -10,7 +10,7 @@
"page-staking-check-address": "Check deposit address",
"page-staking-deposit-address": "Check the deposit address",
"page-staking-deposit-address-desc": "If you’ve already followed the setup instructions on the launchpad, you’ll know you need to send a transaction to the staking deposit contract. We recommend you check the address very carefully. You can find the official address on ethereum.org and a number of other trusted sites.",
- "page-staking-description": "Staking is the act of depositing 32 ETH to activate validator software. As a validator you’ll be responsible for storing data, processing transactions, and adding new blocks to the blockchain. This will keep Ethereum secure for everyone and earn you new ETH in the process. This process, known as proof-of-stake, is being introduced by the Beacon Chain.",
+ "page-staking-description": "Staking is the act of depositing 32 ETH to activate validator software. As a validator you’ll be responsible for storing data, processing transactions, and adding new blocks to the blockchain. This will keep Ethereum secure for everyone and earn you new ETH in the process.",
"page-staking-hero-title": "How to stake your ETH",
"page-staking-hero-header": "Earn rewards while securing Ethereum",
"page-staking-hero-subtitle": "Staking is a public good for the Ethereum ecosystem. Any user with any amount of ETH can help secure the network and earn rewards in the process.",
@@ -139,7 +139,7 @@
"page-staking-section-comparison-rewards-title": "Rewards",
"page-staking-section-comparison-solo-rewards-li1": "Maximum rewards - receive full rewards directly from the protocol",
"page-staking-section-comparison-solo-rewards-li2": "You'll get rewards for batching transactions into a new block or checking the work of other validators to keep the chain running securely",
- "page-staking-section-comparison-solo-rewards-li3": "After The Merge you'll receive unburnt transaction fees for blocks you propose",
+ "page-staking-section-comparison-solo-rewards-li3": "You'll also receive unburnt transaction fees for blocks you propose",
"page-staking-section-comparison-saas-rewards-li1": "Usually involves full protocol rewards minus monthly fee for node operations",
"page-staking-section-comparison-saas-rewards-li2": "Dashboards often available to easily track your validator client",
"page-staking-section-comparison-pools-rewards-li1": "Pooled stakers accrue rewards differently, depending on which method of pooled staking chosen",
@@ -163,15 +163,15 @@
"page-staking-section-comparison-pools-requirements-li1": "Lowest ETH requirements, some projects require as little as 0.01 ETH",
"page-staking-section-comparison-pools-requirements-li2": "Deposit directly from your wallet to different pooled staking platforms or simply trade for one of the staking liquidity tokens",
"page-staking-faq-1-question": "What is a validator?",
- "page-staking-faq-1-answer": "A validator is a virtual entity that lives on the Beacon Chain and participates in the consensus of the Ethereum protocol. Validators are represented by a balance, public key, and other properties. A validator client is the software that acts on behalf of the validator by holding and using its private key. A single validator client can hold many key pairs, controlling many validators.",
+ "page-staking-faq-1-answer": "A validator is a virtual entity that lives on Ethereum and participates in the consensus of the Ethereum protocol. Validators are represented by a balance, public key, and other properties. A validator client is the software that acts on behalf of the validator by holding and using its private key. A single validator client can hold many key pairs, controlling many validators.",
"page-staking-faq-2-question": "Why do I need to have funds at stake?",
"page-staking-faq-2-answer": "A validator has the ability to propose and attest to blocks for the network. To prevent dishonest behavior, users must have their funds at stake. This allows the protocol to penalize malicious actors. Staking is a means to keep you honest, as your actions will have financial consequences.",
"page-staking-faq-3-question": "Can I buy 'Eth2'?",
- "page-staking-faq-3-answer-p1": "There is no 'Eth2' token native to the protocol, as the native token ether (ETH) will not change with the transition to proof-of-stake. Learn more about The Merge",
+ "page-staking-faq-3-answer-p1": "There is no 'Eth2' token native to the protocol, as the native token ether (ETH) did not change when Ethereum switched to proof-of-stake.",
"page-staking-faq-3-answer-p2": "There are derivative tokens/tickers that may represent staked ETH (ie. rETH from Rocket Pool, stETH from Lido, ETH2 from Coinbase). Learn more about staking pools",
"page-staking-faq-4-question": "Is staking already live?",
- "page-staking-faq-4-answer-p1": "Yes and no. Staking has been live since December 1, 2020, but until the Merge happens, the proof-of-stake consensus remains isolated on its own chain, while the existing Ethereum network as we know it continues to operate using proof-of-work. These two chains start separate, but with the Merge, proof-of-work will be fully deprecated, and proof-of-stake will become the sole means of consensus from here-on-out.",
- "page-staking-faq-4-answer-p2": "This means that staking is currently live for users to deposit their ETH, run a validator client, and start earning rewards. After the Merge, stakers will earn higher rewards as validators begin to process transactions and earn fee tips on top of protocol rewards. After the Shanghai update (planned to follow the Merge by a few months), stakers will then be able to withdraw rewards and funds from their validator balance.",
+ "page-staking-faq-4-answer-p1": "Yes. Staking has been live since December 1, 2020",
+ "page-staking-faq-4-answer-p2": "This means that staking is currently live for users to deposit their ETH, run a validator client, and start earning rewards. After the Shanghai update, stakers will then be able to withdraw rewards and funds from their validator balance.",
"page-staking-further-reading-1-link": "Why Proof of Stake (Nov 2020)",
"page-staking-further-reading-author-vitalik-buterin": "Vitalik Buterin",
"page-staking-further-reading-2-link": "Serenity Design Rationale",
diff --git a/src/intl/en/page-upgrades-index.json b/src/intl/en/page-upgrades-index.json
index 3b5b81b6a8a..5867b89d4e4 100644
--- a/src/intl/en/page-upgrades-index.json
+++ b/src/intl/en/page-upgrades-index.json
@@ -46,7 +46,7 @@
"page-upgrades-merge-answer-1": "The Merge is when Mainnet begins using the Beacon Chain for consensus, and proof-of-work is turned off, coming soon.",
"page-upgrades-merge-btn": "More on The Merge",
"page-upgrades-merge-desc": "Mainnet Ethereum will soon 'merge' with the proof-of-stake Beacon Chain, marking the end of energy-intensive mining.",
- "page-upgrades-merge-estimate": "Estimate: 2022",
+ "page-upgrades-merge-estimate": "The Merge is live",
"page-upgrades-merge-mainnet": "What's Mainnet?",
"page-upgrades-merge-mainnet-eth2": "Merging Mainnet and the Beacon Chain",
"page-upgrades-eth-blog": "ethereum.org blog",
diff --git a/src/intl/en/page-upgrades-vision.json b/src/intl/en/page-upgrades-vision.json
index 262fe32802b..a5633392409 100644
--- a/src/intl/en/page-upgrades-vision.json
+++ b/src/intl/en/page-upgrades-vision.json
@@ -18,11 +18,11 @@
"page-upgrades-vision-scalability-desc-3": "Sharding upgrades will spread the data storage requirements across the entire network, no longer requiring every node to hold 100% of the data. Although this doesn't directly address scaling the execution of transactions, this problem is being addressed directly by layer 2 rollup solutions.",
"page-upgrades-vision-scalability-desc-4": "Rollups need cheap storage on layer 1 though to be most effective. Sharding will give Ethereum room to breathe by maximizing the efficiency on rollups, enabling exponential improvements beyond the current 15-45 transactions per second limit.",
"page-upgrades-vision-security": "Security",
- "page-upgrades-vision-security-desc": "The planned upgrades improve Ethereum's security against coordinated attacks, like a 51% attack. This is a type of attack where if someone controls the majority of the network, they can censor or reorder transactions.",
- "page-upgrades-vision-security-desc-3": "The transition to proof-of-stake means that the Ethereum protocol has greater disincentives against attack. This is because in proof-of-stake, the validators who secure the network must stake significant amounts of ETH into the protocol. If they try and attack the network, the protocol can automatically destroy their ETH.",
- "page-upgrades-vision-security-desc-5": "This isn't possible in proof-of-work, where the best a protocol can do is force entities who secure the network (the miners) to lose mining rewards they would have otherwise earned. To achieve the equivalent effect in proof-of-work, the protocol would have to be able to destroy all of a miner's equipment if they try and cheat.",
- "page-upgrades-vision-security-desc-5-link": "More on proof of work",
- "page-upgrades-vision-security-desc-8": "Ethereum's security model also needs to change because of the introduction of sharding. The Beacon Chain will coordinate all of the validators who will be responsible for asserting that all data has been made available, but every node will no longer be required to hold the entire history of the chain. A new role is also anticipated, known as a dedicated block builder, who will work alongside block proposers (validators) for efficient and safe block production. Proof-of-stake is a prerequisite to sharding.",
+ "page-upgrades-vision-security-desc": "The planned upgrades improve Ethereum's security against coordinated attacks.",
+ "page-upgrades-vision-security-desc-3": "In proof-of-stake additional security comes from greater crypto-economic disincentives against attack. This is because, in proof-of-stake, the validators who secure the network must stake significant amounts of ETH into the protocol. If they try and attack the network, the protocol can automatically destroy their ETH.",
+ "page-upgrades-vision-security-desc-5": "However, it is also important that upgrades that protect validators against denial-of-service attacks, enhance their anonymity, and separate block building and block propagation are implemented soon. These upgrades protect individual validators and the network as a whole against liveness attacks and censorship.",
+ "page-upgrades-vision-security-desc-5-link": "More on proof-of-stake",
+ "page-upgrades-vision-security-desc-8": "Ethereum's security model also enables sharding. Validators who will be responsible for asserting that all data has been made available, but individual nodes will no longer be required to hold the entire history of the chain. A new role is also anticipated, known as a dedicated block builder, who will work alongside block proposers (validators) for efficient and safe block production",
"page-upgrades-vision-security-desc-10": "Staking also means you don't need to invest in elite hardware to participate directly in consensus. This should encourage more people to become a validator, increasing the network's decentralization and decreasing the attack surface area.",
"page-upgrades-vision-security-staking": "Stake ETH",
"page-upgrades-vision-security-validator": "You can become a validator by staking your ETH.",
@@ -30,11 +30,11 @@
"page-upgrades-vision-staking-lower": "More on staking",
"page-upgrades-vision-subtitle": "Grow Ethereum until it's powerful enough to help all of humanity.",
"page-upgrades-vision-sustainability": "Sustainability",
- "page-upgrades-vision-sustainability-desc-1": "It's no secret that Ethereum and other blockchains like Bitcoin are energy intensive because of mining.",
- "page-upgrades-vision-sustainability-desc-2": "But Ethereum is moving towards being secured by ETH via staking, not computing power.",
- "page-upgrades-vision-sustainability-desc-3": "Although staking has already been introduced by the Beacon Chain, the Ethereum we use today is still running in parallel until The Merge. One system secured by ETH, the other by computing power.",
- "page-upgrades-vision-sustainability-desc-8": "After significant testing, work is nearing completion on merging Mainnet with the new consensus layer. Mainnet will soon be secured by staked ETH and far less energy intensive.",
- "page-upgrades-vision-sustainability-subtitle": "Ethereum needs to be greener.",
+ "page-upgrades-vision-sustainability-desc-1": "Ethereum is now a green blockchain. The energy consumption was reduced by ~99.95% when proof-of-work was swapped for proof-of-stake.",
+ "page-upgrades-vision-sustainability-desc-2": "Ethereum is now secured via staking, not computing power.",
+ "page-upgrades-vision-sustainability-desc-3": "This sustainability boost also brings security benefits - staked ether makes it much more expensive to attack the chain than under proof-of-work, but less expensive to secure it as less new ETH has to be issued to pay validators than miners.",
+ "page-upgrades-vision-sustainability-desc-8": "The move to proof-of-stake made Ethereum greener and more secure. It is a low-carbon platform for building apps and organizations.",
+ "page-upgrades-vision-sustainability-subtitle": "Ethereum is a green blockchain with strong crypto-economic security.",
"page-upgrades-vision-title": "The Ethereum Vision",
"page-upgrades-vision-title-1": "Clogged network",
"page-upgrades-vision-title-2": "Disk space",
diff --git a/src/intl/en/page-upgrades.json b/src/intl/en/page-upgrades.json
index 932d1d22adb..3c527ad03cf 100644
--- a/src/intl/en/page-upgrades.json
+++ b/src/intl/en/page-upgrades.json
@@ -6,5 +6,8 @@
"page-upgrades-shards-date": "~2023",
"page-upgrades-merge-banner-intro": "The Merge is approaching, and comes with changes to Ethereum.",
"page-upgrades-merge-banner-content-outdated": "Some content on this page is out-of-date related to these changes. Updates are coming soon.",
- "page-upgrades-merge-banner-developers-landing": "Some docs have a banner indicating they are out-of-date. Updates coming soon."
+ "page-upgrades-merge-banner-developers-landing": "Some docs have a banner indicating they are out-of-date. Updates coming soon.",
+ "page-upgrades-post-merge-banner-tutorial-ood": "This tutorial is out of date after the merge and may not work. Please raise a PR if you would like to contribute.",
+ "page-upgrades-post-merge-banner-tutorial-light-node-ood": "This tutorial is out of date after the merge. Light nodes do not currently work on proof-of-stake, but are expected to ship soon.",
+ "page-upgrades-post-merge-banner-governance-ood": "Some content on this page is out-of-date after the merge. Please raise a PR if you would like to contribute."
}
diff --git a/src/intl/en/page-what-is-ethereum.json b/src/intl/en/page-what-is-ethereum.json
index aff959dedb1..9751d41decb 100644
--- a/src/intl/en/page-what-is-ethereum.json
+++ b/src/intl/en/page-what-is-ethereum.json
@@ -87,6 +87,7 @@
"page-what-is-ethereum-energy-desc-1": "Ethereum is currently using proof-of-work mechanism that consumes a large amount of energy. In the coming months (Q3/Q4 2022) Ethereum will undergo its biggest update yet and will switch to proof of stake mechanism which will greatly reduce the environmental impact it has.",
"page-what-is-ethereum-energy-desc-2": "This update will reduce the energy required to secure Ethereum by about 99.95%, creating a more secure network for a much smaller carbon cost. This will make Ethereum a truly low-carbon blockchain while boosting its security and scalability.",
"page-what-is-ethereum-more-on-energy-consumption": "More on energy consumption",
+ "page-what-is-ethereum-energy-consumption-chart-legend": "Annual Energy Consumption in TW/yr",
"page-what-is-ethereum-the-merge-update": "The Merge update",
"page-what-is-ethereum-additional-reading": "Additional reading",
"page-what-is-ethereum-week-in-ethereum": "Week in Ethereum News",
diff --git a/src/intl/es/common.json b/src/intl/es/common.json
index 134bd1b374a..d418faf601a 100644
--- a/src/intl/es/common.json
+++ b/src/intl/es/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logo de Matcha",
"medalla-data-challenge": "Reto de datos Medalla",
"merge": "Fusión",
+ "merge-complete": "¡La fusión está completa! Bienvenido a un nuevo Ethereum más verde.",
"more": "Más",
"more-info": "Más información",
"nav-beginners": "Principiantes",
diff --git a/src/intl/fr/common.json b/src/intl/fr/common.json
index caac283e37c..eee33b88379 100644
--- a/src/intl/fr/common.json
+++ b/src/intl/fr/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logo Matcha",
"medalla-data-challenge": "Défi de données Medalla",
"merge": "Fusionner",
+ "merge-complete": "La fusion s'est produite ! Bienvenue dans un Ethereum plus vert.",
"more": "Plus",
"more-info": "Plus d'infos",
"nav-beginners": "Débutants",
diff --git a/src/intl/hi/common.json b/src/intl/hi/common.json
index 46139134ad2..24c27c2e295 100644
--- a/src/intl/hi/common.json
+++ b/src/intl/hi/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Matcha लोगो",
"medalla-data-challenge": "Medalla डेटा चुनौती",
"merge": "मर्ज करें",
+ "merge-complete": "मर्ज पूरा हो गया है! एक नए हरित Ethereum में आपका स्वागत है।",
"more": "अधिक",
"more-info": "अधिक जानकारी",
"nav-beginners": "नई शुरुआत",
diff --git a/src/intl/id/common.json b/src/intl/id/common.json
index f269a8b7401..0a2059f6d03 100644
--- a/src/intl/id/common.json
+++ b/src/intl/id/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logo Matcha",
"medalla-data-challenge": "Tantangan data Medalla",
"merge": "Gabungkan",
+ "merge-complete": "Penggabungan telah selesai! Selamat datang di Ethereum baru yang lebih hijau.",
"more": "Lebih Banyak",
"more-info": "Info lebih lanjut",
"nav-beginners": "Pemula",
diff --git a/src/intl/it/common.json b/src/intl/it/common.json
index 6916b738462..1590085e33f 100644
--- a/src/intl/it/common.json
+++ b/src/intl/it/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logo di Matcha",
"medalla-data-challenge": "Medalla data challenge",
"merge": "Fusione",
+ "merge-complete": "La fusione è completa! Benvenuti in un nuovo Ethereum più verde.",
"more": "Altro",
"more-info": "Maggiori informazioni",
"nav-beginners": "Principianti",
diff --git a/src/intl/ja/common.json b/src/intl/ja/common.json
index e16ca21e056..cf3d6509b57 100644
--- a/src/intl/ja/common.json
+++ b/src/intl/ja/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Matcha ロゴ",
"medalla-data-challenge": "Medallaデータチャレンジ",
"merge": "マージ",
+ "merge-complete": "マージ完了! より環境に優しくなったイーサリアムへようこそ。",
"more": "もっと見る",
"more-info": "詳細",
"nav-beginners": "初心者",
diff --git a/src/intl/ko/common.json b/src/intl/ko/common.json
index a573175227c..63f6453c29d 100644
--- a/src/intl/ko/common.json
+++ b/src/intl/ko/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Matcha 로고",
"medalla-data-challenge": "Medalla 데이터 문제",
"merge": "병합",
+ "merge-complete": "머지가 완료되었습니다! 친환경적인 새로운 이더리움의 세계에 오신 것을 환영합니다.",
"more": "더 보기",
"more-info": "상세 정보",
"nav-beginners": "입문자",
diff --git a/src/intl/nl/common.json b/src/intl/nl/common.json
index fcc7b44c8b0..2ff8e6d4576 100644
--- a/src/intl/nl/common.json
+++ b/src/intl/nl/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Matcha-logo",
"medalla-data-challenge": "Medalla-gegevensuitdaging",
"merge": "Samenvoegen",
+ "merge-complete": "De Merge is compleet! Welkom bij een nieuw groener Ethereum.",
"more": "Meer",
"more-info": "Meer info",
"nav-beginners": "Beginners",
diff --git a/src/intl/pl/common.json b/src/intl/pl/common.json
index b5ca3ec7be2..4fec2ef4d51 100644
--- a/src/intl/pl/common.json
+++ b/src/intl/pl/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logo Matcha",
"medalla-data-challenge": "Wyzwanie z danymi Medalla",
"merge": "Połącz",
+ "merge-complete": "Merge jest gotowy! Witajcie w nowym, bardziej zielonym Ethereum.",
"more": "Więcej",
"more-info": "Więcej informacji",
"nav-beginners": "Początkujący",
diff --git a/src/intl/pt-br/common.json b/src/intl/pt-br/common.json
index dd64061d872..e30f9c687d1 100644
--- a/src/intl/pt-br/common.json
+++ b/src/intl/pt-br/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logotipo da Matcha",
"medalla-data-challenge": "Desafio de dados Medalla",
"merge": "Integração",
+ "merge-complete": "A Fusão está completa! Bem-vindo a uma nova Ethereum mais verde.",
"more": "Mais",
"more-info": "Mais informações",
"nav-beginners": "Principiantes",
diff --git a/src/intl/pt/common.json b/src/intl/pt/common.json
index ae098a0e92e..ecd28b837a6 100644
--- a/src/intl/pt/common.json
+++ b/src/intl/pt/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logótipo da Matcha",
"medalla-data-challenge": "Desafio de dados Medalla",
"merge": "Fundir",
+ "merge-complete": "A fusão está completa! Bem-vindo a um novo Ethereum mais verde.",
"more": "Mais",
"more-info": "Mais informação",
"nav-beginners": "Principiantes",
diff --git a/src/intl/ru/common.json b/src/intl/ru/common.json
index 46f67cbcc10..0293d1cc756 100644
--- a/src/intl/ru/common.json
+++ b/src/intl/ru/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Логотип Matcha",
"medalla-data-challenge": "Конкурс данных Medalla",
"merge": "Объединение",
+ "merge-complete": "Слияние завершено! Добро пожаловать в новый экологичный Ethereum.",
"more": "Больше",
"more-info": "Подробнее",
"nav-beginners": "Начинающим",
diff --git a/src/intl/sw/common.json b/src/intl/sw/common.json
index 8d27709a7f9..5c7c05b9b4c 100644
--- a/src/intl/sw/common.json
+++ b/src/intl/sw/common.json
@@ -172,6 +172,7 @@
"matcha-logo": "Nembo ya Matcha",
"medalla-data-challenge": "Changamoto ya data ya Medella",
"merge": "Unganisha",
+ "merge-complete": "Muungano umekamilika! Karibu kwenye Ethereum inayojali mazingira.",
"more": "Zaidi",
"more-info": "Habari zaidi",
"nav-beginners": "Wanaoanza",
diff --git a/src/intl/tr/common.json b/src/intl/tr/common.json
index fa2666d4bd6..ae82f726aba 100644
--- a/src/intl/tr/common.json
+++ b/src/intl/tr/common.json
@@ -188,6 +188,7 @@
"matcha-logo": "Matcha logosu",
"medalla-data-challenge": "Medalla veri yarışması",
"merge": "Birleşme",
+ "merge-complete": "(Ethereum birleşmesi) tamamlandı! Daha yeşil bir Ethereum’a hoşgeldiniz.",
"more": "Daha fazlası",
"more-info": "Daha fazla bilgi",
"nav-beginners": "Yeni başlayanlar",
diff --git a/src/intl/vi/common.json b/src/intl/vi/common.json
index cdf0a59d7a1..9d343240437 100644
--- a/src/intl/vi/common.json
+++ b/src/intl/vi/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Logo Matcha",
"medalla-data-challenge": "Thử thách dữ liệu Medalla",
"merge": "Gộp",
+ "merge-complete": "Hợp nhất đã hoàn tất! Chào mừng bạn đến với kỷ nguyên xanh mới của Ethereum.",
"more": "Xem thêm",
"more-info": "Thông tin chi tiết",
"nav-beginners": "Người mới bắt đầu",
diff --git a/src/intl/zh/common.json b/src/intl/zh/common.json
index 4a23384dca6..2e3fa187381 100644
--- a/src/intl/zh/common.json
+++ b/src/intl/zh/common.json
@@ -184,6 +184,7 @@
"matcha-logo": "Matcha徽标",
"medalla-data-challenge": "Medalla 数据挑战赛",
"merge": "合并",
+ "merge-complete": "大合并业已完成!欢迎进入一个崭新的、更加绿色环保的以太坊",
"more": "更多",
"more-info": "更多信息",
"nav-beginners": "初学者",
diff --git a/src/pages-conditional/what-is-ethereum.tsx b/src/pages-conditional/what-is-ethereum.tsx
index f663e0a4d4b..e3d088f9db7 100644
--- a/src/pages-conditional/what-is-ethereum.tsx
+++ b/src/pages-conditional/what-is-ethereum.tsx
@@ -169,6 +169,7 @@ const Section = styled.div<{
bgColor?: string
padding?: string
}>`
+ width: 100%;
padding: ${({ padding }) => padding ?? "3rem 2rem"};
background-color: ${({ bgColor = "transparent" }) => bgColor};
@@ -310,52 +311,6 @@ const WhatIsEthereumPage = ({
},
]
- const smallBreakpoint = Number(theme.breakpoints.s.replace("px", ""))
- const energyConsumptionChartData = [
- {
- name: "Youtube",
- amount: 244,
- color: "#FF0000",
- },
- {
- name: "Gold mining",
- amount: 240,
- color: "#D7B14A",
- breakpoint: smallBreakpoint,
- },
- {
- name: "BTC PoW",
- amount: 200,
- color: "#F2A900",
- },
- {
- name: "ETH PoW",
- amount: 112,
- color: "#C1B6F5",
- },
- {
- name: "Netflix",
- amount: 94,
- color: "#E50914",
- },
- {
- name: "Gaming",
- amount: 34,
- color: "#71BB8A",
- breakpoint: smallBreakpoint,
- },
- {
- name: "Paypal",
- amount: 0.26,
- color: "#C1B6F5",
- },
- {
- name: "ETH PoS",
- amount: 0.01,
- color: "#C1B6F5",
- },
- ]
-
const tabs = [
{
title: translateMessageId(
@@ -906,10 +861,7 @@ const WhatIsEthereumPage = ({
-
+
diff --git a/src/pages/developers/index.tsx b/src/pages/developers/index.tsx
index 058d959a743..ffbd5facbda 100644
--- a/src/pages/developers/index.tsx
+++ b/src/pages/developers/index.tsx
@@ -8,7 +8,6 @@ import Card from "../../components/Card"
import Callout from "../../components/Callout"
import Link from "../../components/Link"
import Translation from "../../components/Translation"
-import PreMergeBanner from "../../components/PreMergeBanner"
import ButtonLink from "../../components/ButtonLink"
import PageMetadata from "../../components/PageMetadata"
import {
@@ -251,9 +250,6 @@ const DevelopersPage = ({
title={translateMessageId("page-developer-meta-title", intl)}
description={translateMessageId("page-developers-meta-desc", intl)}
/>
-
-
-
diff --git a/src/pages/developers/tutorials.tsx b/src/pages/developers/tutorials.tsx
index 62055a7712d..f63afcef238 100644
--- a/src/pages/developers/tutorials.tsx
+++ b/src/pages/developers/tutorials.tsx
@@ -563,7 +563,6 @@ export const query = graphql`
skill
published
lang
- preMergeBanner
}
}
}
diff --git a/src/pages/index.tsx b/src/pages/index.tsx
index cf03de623c3..a241a9ad8f0 100644
--- a/src/pages/index.tsx
+++ b/src/pages/index.tsx
@@ -23,7 +23,6 @@ import {
GrayContainer,
LeftColumn,
} from "../components/SharedStyledComponents"
-import PreMergeBanner from "../components/PreMergeBanner"
import { translateMessageId, isLangRightToLeft } from "../utils/translations"
import { getImage } from "../utils/image"
@@ -31,6 +30,8 @@ import SimpleWalletContent from "!!raw-loader!../data/SimpleWallet.sol"
import SimpleTokenContent from "!!raw-loader!../data/SimpleToken.sol"
import CreateWalletContent from "!!raw-loader!../data/CreateWallet.js"
import SimpleDomainRegistryContent from "!!raw-loader!../data/SimpleDomainRegistry.sol"
+import { useConsoleEasterEgg } from "../hooks/useConsoleEasterEgg"
+import { useConfetti } from "../hooks/useConfetti"
const Hero = styled(GatsbyImage)`
width: 100%;
@@ -423,6 +424,10 @@ const HomePage = ({
setActiveCode(id)
setModalOpen(true)
}
+
+ useConsoleEasterEgg()
+ useConfetti("confetti-easter-egg")
+
const cards = [
{
image: getImage(data.robotfixed),
@@ -561,12 +566,12 @@ const HomePage = ({
title={translateMessageId("page-index-meta-title", intl)}
description={translateMessageId("page-index-meta-description", intl)}
/>
-
+