mirror of
https://github.com/status-im/eth2.0-specs.git
synced 2025-01-20 07:29:02 +00:00
Merge pull request #2686 from ethereum/tx-limits
fix gossip and tx size limits for the merge
This commit is contained in:
commit
2fc0564a5a
@ -2,10 +2,10 @@
|
|||||||
|
|
||||||
# Execution
|
# Execution
|
||||||
# ---------------------------------------------------------------
|
# ---------------------------------------------------------------
|
||||||
|
# 2**30 (= 1,073,741,824)
|
||||||
|
MAX_BYTES_PER_TRANSACTION: 1073741824
|
||||||
# 2**20 (= 1,048,576)
|
# 2**20 (= 1,048,576)
|
||||||
MAX_BYTES_PER_TRANSACTION: 1048576
|
MAX_TRANSACTIONS_PER_PAYLOAD: 1048576
|
||||||
# 2**14 (= 16,384)
|
|
||||||
MAX_TRANSACTIONS_PER_PAYLOAD: 16384
|
|
||||||
# 2**8 (= 256)
|
# 2**8 (= 256)
|
||||||
BYTES_PER_LOGS_BLOOM: 256
|
BYTES_PER_LOGS_BLOOM: 256
|
||||||
# 2**10 (= 1,024)
|
# 2**10 (= 1,024)
|
||||||
|
@ -2,10 +2,10 @@
|
|||||||
|
|
||||||
# Execution
|
# Execution
|
||||||
# ---------------------------------------------------------------
|
# ---------------------------------------------------------------
|
||||||
|
# 2**30 (= 1,073,741,824)
|
||||||
|
MAX_BYTES_PER_TRANSACTION: 1073741824
|
||||||
# 2**20 (= 1,048,576)
|
# 2**20 (= 1,048,576)
|
||||||
MAX_BYTES_PER_TRANSACTION: 1048576
|
MAX_TRANSACTIONS_PER_PAYLOAD: 1048576
|
||||||
# 2**14 (= 16,384)
|
|
||||||
MAX_TRANSACTIONS_PER_PAYLOAD: 16384
|
|
||||||
# 2**8 (= 256)
|
# 2**8 (= 256)
|
||||||
BYTES_PER_LOGS_BLOOM: 256
|
BYTES_PER_LOGS_BLOOM: 256
|
||||||
# 2**10 (= 1,024)
|
# 2**10 (= 1,024)
|
||||||
|
@ -59,8 +59,8 @@ This patch adds transaction execution to the beacon chain as part of the Merge f
|
|||||||
|
|
||||||
| Name | Value |
|
| Name | Value |
|
||||||
| - | - |
|
| - | - |
|
||||||
| `MAX_BYTES_PER_TRANSACTION` | `uint64(2**20)` (= 1,048,576) |
|
| `MAX_BYTES_PER_TRANSACTION` | `uint64(2**30)` (= 1,073,741,824) |
|
||||||
| `MAX_TRANSACTIONS_PER_PAYLOAD` | `uint64(2**14)` (= 16,384) |
|
| `MAX_TRANSACTIONS_PER_PAYLOAD` | `uint64(2**20)` (= 1,048,576) |
|
||||||
| `BYTES_PER_LOGS_BLOOM` | `uint64(2**8)` (= 256) |
|
| `BYTES_PER_LOGS_BLOOM` | `uint64(2**8)` (= 256) |
|
||||||
| `GAS_LIMIT_DENOMINATOR` | `uint64(2**10)` (= 1,024) |
|
| `GAS_LIMIT_DENOMINATOR` | `uint64(2**10)` (= 1,024) |
|
||||||
| `MIN_GAS_LIMIT` | `uint64(5000)` (= 5,000) |
|
| `MIN_GAS_LIMIT` | `uint64(5000)` (= 5,000) |
|
||||||
|
@ -14,6 +14,7 @@ Readers should understand the Phase 0 and Altair documents and use them as a bas
|
|||||||
|
|
||||||
- [Warning](#warning)
|
- [Warning](#warning)
|
||||||
- [Modifications in the Merge](#modifications-in-the-merge)
|
- [Modifications in the Merge](#modifications-in-the-merge)
|
||||||
|
- [Configuration](#configuration)
|
||||||
- [The gossip domain: gossipsub](#the-gossip-domain-gossipsub)
|
- [The gossip domain: gossipsub](#the-gossip-domain-gossipsub)
|
||||||
- [Topics and messages](#topics-and-messages)
|
- [Topics and messages](#topics-and-messages)
|
||||||
- [Global topics](#global-topics)
|
- [Global topics](#global-topics)
|
||||||
@ -23,6 +24,11 @@ Readers should understand the Phase 0 and Altair documents and use them as a bas
|
|||||||
- [Messages](#messages)
|
- [Messages](#messages)
|
||||||
- [BeaconBlocksByRange v2](#beaconblocksbyrange-v2)
|
- [BeaconBlocksByRange v2](#beaconblocksbyrange-v2)
|
||||||
- [BeaconBlocksByRoot v2](#beaconblocksbyroot-v2)
|
- [BeaconBlocksByRoot v2](#beaconblocksbyroot-v2)
|
||||||
|
- [Design decision rationale](#design-decision-rationale)
|
||||||
|
- [Gossipsub](#gossipsub)
|
||||||
|
- [Why was the max gossip message size increased at the Merge?](#why-was-the-max-gossip-message-size-increased-at-the-merge)
|
||||||
|
- [Req/Resp](#reqresp)
|
||||||
|
- [Why was the max chunk response size increased at the Merge?](#why-was-the-max-chunk-response-size-increased-at-the-merge)
|
||||||
|
|
||||||
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
|
<!-- END doctoc generated TOC please keep comment here to allow auto update -->
|
||||||
<!-- /TOC -->
|
<!-- /TOC -->
|
||||||
@ -34,6 +40,15 @@ Refer to the note in the [validator guide](./validator.md) for further details.
|
|||||||
|
|
||||||
# Modifications in the Merge
|
# Modifications in the Merge
|
||||||
|
|
||||||
|
## Configuration
|
||||||
|
|
||||||
|
This section outlines modifications constants that are used in this spec.
|
||||||
|
|
||||||
|
| Name | Value | Description |
|
||||||
|
|---|---|---|
|
||||||
|
| `GOSSIP_MAX_SIZE_MERGE` | `10 * 2**20` (= 10,485,760, 10 MiB) | The maximum allowed size of uncompressed gossip messages starting at the Merge upgrade. |
|
||||||
|
| `MAX_CHUNK_SIZE_MERGE` | `10 * 2**20` (= 10,485,760, 10 MiB) | The maximum allowed size of uncompressed req/resp chunked responses starting at the Merge upgrade. |
|
||||||
|
|
||||||
## The gossip domain: gossipsub
|
## The gossip domain: gossipsub
|
||||||
|
|
||||||
Some gossip meshes are upgraded in the Merge to support upgraded types.
|
Some gossip meshes are upgraded in the Merge to support upgraded types.
|
||||||
@ -43,7 +58,12 @@ Some gossip meshes are upgraded in the Merge to support upgraded types.
|
|||||||
Topics follow the same specification as in prior upgrades.
|
Topics follow the same specification as in prior upgrades.
|
||||||
All topics remain stable except the beacon block topic which is updated with the modified type.
|
All topics remain stable except the beacon block topic which is updated with the modified type.
|
||||||
|
|
||||||
The specification around the creation, validation, and dissemination of messages has not changed from the Phase 0 and Altair documents.
|
The specification around the creation, validation, and dissemination of messages has not changed from the Phase 0 and Altair documents unless explicitly noted here.
|
||||||
|
|
||||||
|
Starting at the Merge upgrade, each gossipsub [message](https://github.com/libp2p/go-libp2p-pubsub/blob/master/pb/rpc.proto#L17-L24)
|
||||||
|
has a maximum size of `GOSSIP_MAX_SIZE_MERGE`.
|
||||||
|
Clients MUST reject (fail validation) messages that are over this size limit.
|
||||||
|
Likewise, clients MUST NOT emit or propagate messages larger than this limit.
|
||||||
|
|
||||||
The derivation of the `message-id` remains stable.
|
The derivation of the `message-id` remains stable.
|
||||||
|
|
||||||
@ -74,9 +94,6 @@ Alias `block = signed_beacon_block.message`, `execution_payload = block.body.exe
|
|||||||
-- i.e. `execution_payload.timestamp == compute_timestamp_at_slot(state, block.slot)`.
|
-- i.e. `execution_payload.timestamp == compute_timestamp_at_slot(state, block.slot)`.
|
||||||
- _[REJECT]_ Gas used is less than the gas limit --
|
- _[REJECT]_ Gas used is less than the gas limit --
|
||||||
i.e. `execution_payload.gas_used <= execution_payload.gas_limit`.
|
i.e. `execution_payload.gas_used <= execution_payload.gas_limit`.
|
||||||
- _[REJECT]_ The execution payload transaction list data is within expected size limits,
|
|
||||||
the data MUST NOT be larger than the SSZ list-limit,
|
|
||||||
and a client MAY be more strict.
|
|
||||||
|
|
||||||
*Note*: Additional [gossip validations](https://github.com/ethereum/devp2p/blob/master/caps/eth.md#block-encoding-and-validity)
|
*Note*: Additional [gossip validations](https://github.com/ethereum/devp2p/blob/master/caps/eth.md#block-encoding-and-validity)
|
||||||
(see block "data validity" conditions) that rely more heavily on execution-layer state and logic are currently under consideration.
|
(see block "data validity" conditions) that rely more heavily on execution-layer state and logic are currently under consideration.
|
||||||
@ -94,7 +111,12 @@ details on how to handle transitioning gossip topics for the Merge.
|
|||||||
|
|
||||||
**Protocol ID:** `/eth2/beacon_chain/req/beacon_blocks_by_range/2/`
|
**Protocol ID:** `/eth2/beacon_chain/req/beacon_blocks_by_range/2/`
|
||||||
|
|
||||||
Request and Response remain unchanged.
|
Request and Response remain unchanged unless explicitly noted here.
|
||||||
|
|
||||||
|
Starting at the Merge upgrade,
|
||||||
|
a global maximum uncompressed byte size of `MAX_CHUNK_SIZE_MERGE` MUST be applied to all method response chunks
|
||||||
|
regardless of type specific bounds that *MUST* also be respected.
|
||||||
|
|
||||||
The Merge fork-digest is introduced to the `context` enum to specify the Merge block type.
|
The Merge fork-digest is introduced to the `context` enum to specify the Merge block type.
|
||||||
|
|
||||||
Per `context = compute_fork_digest(fork_version, genesis_validators_root)`:
|
Per `context = compute_fork_digest(fork_version, genesis_validators_root)`:
|
||||||
@ -123,3 +145,44 @@ Per `context = compute_fork_digest(fork_version, genesis_validators_root)`:
|
|||||||
| `GENESIS_FORK_VERSION` | `phase0.SignedBeaconBlock` |
|
| `GENESIS_FORK_VERSION` | `phase0.SignedBeaconBlock` |
|
||||||
| `ALTAIR_FORK_VERSION` | `altair.SignedBeaconBlock` |
|
| `ALTAIR_FORK_VERSION` | `altair.SignedBeaconBlock` |
|
||||||
| `MERGE_FORK_VERSION` | `merge.SignedBeaconBlock` |
|
| `MERGE_FORK_VERSION` | `merge.SignedBeaconBlock` |
|
||||||
|
|
||||||
|
# Design decision rationale
|
||||||
|
|
||||||
|
## Gossipsub
|
||||||
|
|
||||||
|
### Why was the max gossip message size increased at the Merge?
|
||||||
|
|
||||||
|
With the addition of `ExecutionPayload` to `BeaconBlock`s, there is a dynamic
|
||||||
|
field -- `transactions` -- which can validly exceed the `GOSSIP_MAX_SIZE` limit (1 MiB) put in place in
|
||||||
|
place at Phase 0. At the `GAS_LIMIT` (~30M) currently seen on mainnet in 2021, a single transaction
|
||||||
|
filled entirely with data at a cost of 16 gas per byte can create a valid
|
||||||
|
`ExecutionPayload` of ~2 MiB. Thus we need a size limit to at least account for
|
||||||
|
current mainnet conditions.
|
||||||
|
|
||||||
|
Geth currently has a [max gossip message size](https://github.com/ethereum/go-ethereum/blob/3ce9f6d96f38712f5d6756e97b59ccc20cc403b3/eth/protocols/eth/protocol.go#L49) of 10 MiB.
|
||||||
|
To support backward compatibility with this previously defined network limit,
|
||||||
|
we adopt `GOSSIP_MAX_SIZE_MERGE` of 10 MiB for maximum gossip sizes at the
|
||||||
|
point of the Merge and beyond. Note, that clients SHOULD still reject objects
|
||||||
|
that exceed their maximum theoretical bounds which in most cases is less than `GOSSIP_MAX_SIZE_MERGE`.
|
||||||
|
|
||||||
|
Note, that due to additional size induced by the `BeaconBlock` contents (e.g.
|
||||||
|
proposer signature, operations lists, etc) this does reduce the
|
||||||
|
theoretical max valid `ExecutionPayload` (and `transactions` list) size as
|
||||||
|
slightly lower than 10 MiB. Considering that `BeaconBlock` max size is on the
|
||||||
|
order of 128 KiB in the worst case and the current gas limit (~30M) bounds max blocksize to less
|
||||||
|
than 2 MiB today, this marginal difference in theoretical bounds will have zero
|
||||||
|
impact on network functionality and security.
|
||||||
|
|
||||||
|
## Req/Resp
|
||||||
|
|
||||||
|
### Why was the max chunk response size increased at the Merge?
|
||||||
|
|
||||||
|
Similar to the discussion about the maximum gossip size increase, the
|
||||||
|
`ExecutionPayload` type can cause `BeaconBlock`s to exceed the 1 MiB bounds put
|
||||||
|
in place during Phase 0.
|
||||||
|
|
||||||
|
As with the gossip limit, 10 MiB is selected because this is firmly below any
|
||||||
|
valid block sizes in the range of gas limits expected in the medium term.
|
||||||
|
|
||||||
|
As with both gossip and req/rsp maximum values, type-specific limits should
|
||||||
|
always by simultaneously respected.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user