2022-05-25 07:21:18 -05:00
---
title: The Merge
sort_key: A2
---
2022-05-26 16:43:37 -05:00
As an Execution-Layer (EL) client, Geth supports the transition of Ethereum from proof-of-work (PoW) to
2022-05-26 17:49:04 -05:00
proof-of-stake (PoS), a.k.a. [The Merge ](https://ethereum.org/en/upgrades/merge/ ).
2022-05-26 16:43:37 -05:00
### What happens to Geth?
2022-05-26 17:49:04 -05:00
The merge changes Ethereum's PoW consensus mechanism to PoS. At the moment of the merge,
2022-05-26 16:43:37 -05:00
Geth switches off its mining algorithm and block gossip functions. Geth's role after the merge is
2022-05-26 17:49:04 -05:00
executing transactions and generating execution payloads using the [EVM ](https://ethereum.org/en/developers/docs/evm ).
2022-05-26 16:43:37 -05:00
2022-05-26 17:49:04 -05:00
From a user's perspective Geth will not change much at the merge. Responsibility for consensus logic and
2022-05-26 16:43:37 -05:00
block propagation are handed over to the consensus layer, but all of Geth's other functionality remains
intact. This means transactions, contract deployments and data queries can still be handled by Geth using
the same methods as before.
2022-05-25 07:21:18 -05:00
### Transition
2022-05-26 16:43:37 -05:00
The transition from PoW to PoS will happen when a pre-announced total difficulty is reached by the chain.
2022-05-25 07:21:18 -05:00
This is unlike usual forks which occur at a certain scheduled block number.
2022-05-26 16:43:37 -05:00
The total difficulty threshold that triggers the Merge is also known as the [*Terminal
2022-05-26 17:49:04 -05:00
Total Difficulty* (TTD)](https://ethereum.org/en/glossary/#terminal-total-difficulty). In
2022-06-06 11:19:22 -05:00
case of an emergency delay, the TTD can be overriden using the `--override.terminaltotaldifficulty` command-line
2022-05-26 17:49:04 -05:00
flag.
2022-05-25 07:21:18 -05:00
2022-05-26 17:49:04 -05:00
#### Ropsten Transition
In advance of the Mainnet merge, several public testnets will transition from PoW to PoS.
The first public testnet to merge will be Ropsten. As the Ropsten merge approaches, Geth
users will need to prepare to ensure a smooth transition.
2022-06-22 03:41:32 -05:00
{% include note.html content="The merge event did not go smoothly on Ropsten. However, if you are running Geth v1.10.19 or later, no action is required. If you are running Geth v1.10.18 or earlier, you should use `--override.terminaltotaldifficulty 50000000000000000` when launching Geth for Ropsten." %}
2022-05-25 07:21:18 -05:00
### Consensus client
2022-05-26 16:43:37 -05:00
After the merge, Geth will no longer be able to follow the head of the chain unless it is connected to a second
piece of software known as a ["consensus client" ](https://ethereum.org/en/developers/docs/nodes-and-clients/#consensus-clients )
which handles all of Ethereum's consensus logic.
2022-05-25 07:21:18 -05:00
2022-05-26 16:43:37 -05:00
The consensus client communicates with Geth using the `engine` API over a local RPC connection. The consensus client
is responsible for gossiping blocks, block proposal, attestation and fork choice.
2022-05-25 07:21:18 -05:00
2022-05-26 16:43:37 -05:00
Geth must be connected to a consensus client in advance of the merge so that the two pieces of software can get in sync and
transition smoothly by coordinating together. There are several choices of [consensus client implementations][cl-list].
2022-05-25 07:21:18 -05:00
2022-05-26 16:43:37 -05:00
Note that CL clients are equipped with two modes. One for following the beacon chain (Beacon node), and another mode
used for validators. **It is NOT required to run a validator or stake 32 ETH in order to follow the chain!**
2022-05-25 07:21:18 -05:00
### EL - CL communication
2022-05-26 16:43:37 -05:00
ELs and CLs communicate using a [JSON-RPC API][engineapi] under the namespace `engine` which is exposed by Geth.
2022-05-25 07:21:18 -05:00
2022-05-26 16:43:37 -05:00
The `engine` API is authenticated via [JWT ](https://jwt.io ). If a TTD is set for the given network, as is the
case for Ropsten, Geth will:
2022-05-25 07:21:18 -05:00
- Generate a JWT secret under the path `<datadir>/geth/jwtsecret` . This secret is needed
both by Geth and the CL client.
- Open HTTP and WS endpoints on the authenticated port 8551.
This is what it looks like by default:
```shell
2022-06-09 09:45:34 -05:00
geth --ropsten --datadir ~/.ropsten --override.terminaltotaldifficulty 50000000000000000
2022-05-25 07:21:18 -05:00
```
```terminal
INFO [05-25|11:04:41.179] Starting Geth on Ropsten testnet...
...
WARN [05-25|11:04:41.520] Catalyst mode enabled protocol=eth
INFO [05-25|11:04:41.627] Generated JWT secret path=/home/user/.ropsten/geth/jwtsecret
INFO [05-25|11:04:41.628] WebSocket enabled url=ws://127.0.0.1:8551
INFO [05-25|11:04:41.628] HTTP server started endpoint=127.0.0.1:8551 auth=true prefix= cors=localhost vhosts=localhost
```
### Engine API Authentication
2022-05-26 16:43:37 -05:00
The listening address of the engine API is configurable. It is also possible to self-generate the JWT secret and feed the resulting file to Geth. To generate the secret, run:
2022-05-25 07:21:18 -05:00
```shell
openssl rand -hex 32 | tr -d "\n" > "/tmp/jwtsecret"
```
Now configure authentication using Geth flags:
```shell
2022-06-09 09:45:34 -05:00
geth --ropsten --datadir ~/.ropsten --authrpc.addr localhost --authrpc.port 8551 --authrpc.vhosts localhost --authrpc.jwtsecret /tmp/jwtsecret --override.terminaltotaldifficulty 50000000000000000
2022-05-25 07:21:18 -05:00
```
[engineapi]: https://github.com/ethereum/execution-apis/blob/main/src/engine/specification.md
[cl-list]: https://ethereum.org/en/developers/docs/nodes-and-clients/#consensus-clients