Cointime

Download App
iOS & Android

On Block Sizes, Gas Limits and Scalability

From Ethresearch by Nerolation

Thanks to Alex StokesMatt (lightclients) and Matt Solomon for feedback and review!

There has been much discussion about raising Ethereum’s block gas limit recently.Some argue for bigger blocks based on Moore’s law, some based on a personal gut feeling, some are just trolling around and others are afraid that other chains like Solana will outpace Ethereum when it comes to widespread user adoption.

In the following, I want to present some charts and figures that may be helpful in guiding us towards a decision that maxes out the gas limit without compromising Ethereum’s decentralization.

From the beginning

In contrast to Bitcoin, Ethereum doesn’t have a fixed block size limit. Instead, Ethereum relies on a flexible block size mechanism governed by a unit called “gas.” Gas in Ethereum is a unit that measures the amount of computational effort required to execute operations like transactions or smart contracts. Each operation in Ethereum requires a certain amount of gas to complete, and each block has a gas limit, which determines how many operations can fit into a block.

Ethereum started with a gas limit of 5000 gas per block in 2015.This limit was then quickly raised to ~3 million and then to ~4.7 million later in 2016.With the Tangerine Whistle hardfork and, more specifically, EIP-150 in 2016, the gas limit was raised to 5.5 million, based on a repricing of various IO-heavy opcodes as a response to DoS attacks. After these attacks, the limit was continuously raised by miners to ~6.7 million in July 2017, then ~8 million in December 2017, then ~10 million in September 2019, then 12.5 million in August 2020 and finally to ~15 million in April 2021.

gas_used_over_time1200×400 35 KB

Further on, with the Spurious Dragon, Byzantium, Constantinople, Istanbul and Berlin hardforks, the pricing of certain opcodes was further refined. Examples of these refinements are EIP-145EIP-160EIP-1052EIP-1108EIP-1884EIP-2028EIP-2200EIP-2565 and EIP-2929.

The most significant change to Ethereum’s fee market happened with the London hardfork in August 2021 and more specifically EIP-1559.EIP-1559 introduced a base fee that dynamically adjusts over time/blocks depending on the demand for blockspace. At the same time a so called target has been introduced and set to 15 million gas per block. This target is used to guide the dynamic adjustment of the base fee. If the total gas used in a block exceeds this target, the base fee increases for the subsequent block. Conversely, if the total gas used is below the target, the base fee decreases. This mechanism aims to create a more predictable fee market and improve the user experience by stabilizing transaction costs. Additionally, EIP-1559 also introduced a burning mechanism for the base fee, permanently removing that portion of ether from circulation. This hardended the protocol’s sustainability while creating the ultra sound money meme.

Under EIP-1559, there is also a maximum (or “hard cap”) gas limit, set to twice the target, which is 30 million gas. This means that a block can include transactions using up to 30 million gas.

gas_used_since_london1200×400 19.3 KB

Since then Ethereum’s block gas limit remained the same and, as of 2024, it is still at 30 million gas per block.

Are we ready for an increase?

Recently, some raised concerns about Ethereum’s gas limit and demanded it to be increased. In the most recent Ethereum Foundation AMA on Reddit, Vitalik considered the idea of increasing the gas limit by 33% to 40 million. He based his reasoning on Moore’s law which states that the number of transistors on a microchip doubles approximately every two years, leading to a corresponding increase in computational power. This principle suggests that network capabilities, including processing and handling transactions, could also increase over time.

Support came from Dankrad and Ansgar, both researchers at the Ethereum Foundation, who like the idea of increasing the gas limit after evaluating the situation after the Dencun upgrade. In addition, Pari from the Ethereum Foundations published a post exploring paths for a potential gas limit increase.Others like Peter and Marius from Geth raised concerns about increasing the gas limit, especially without having appropriate tooling/monitoring in place. These concerns were specifically based on accelerating state growth, syncing times and reorged block rates.

What is the block size?

The size of a block can be measured in two ways:

  • Gas Usage
  • Block size (in bytes)

While both of these measures correlate, they must be considered independently.For example, a block that contains much non-zero calldata bytes might be big in terms of its size in bytes while the actual gas usage (16 gas for non-zero bytes) may still be relatively small.

Ignoring compression, the maximum block size that can be achieved today while still obeying the 128 KB per transaction limit of Geth is ~6.88 MB. Such a block would max out the number of 128 KB transactions in a block. In practice, these are 55 transactions containing ~130,900 bytes of zero-byte calldata (4 gas per byte) and one transaction filling up the remaining space. However, after snappy compressing such a block we end up at ~0.32 MB, which is negligible.The largest possible block after compression contains 15 transactions filled with non-zero calldata and can have a size of ~1.77 MB.

So, as of today, 1.77 MB represents the realistic upper-bound block size for an execution layer block.

Focusing on this maximum block size, we can identify several factors that influence it:

  • Gas limit: Of course, the gas limit has an impact on the maximum block size. The higher it is, the more data can be put into a block.
  • Pricing of operations and data: The cheaper an operation in terms of gas, the more often the operation can be executed within a block. While operations such as CALLDATALOAD or CALLDATACOPY, both costing 3 gas, are relatively cheap, other opcodes such as CREATE are more expensive. The more expensive the opcodes used in a block, the less space for calldata (or other operations) in that block.
  • Client limits: While not that obvious, client limits such as the 128kb limit per transaction of Geth can also impact the final block size. Since every transaction costs 21k gas as a fixed fee, the lower the client limit per transaction, the more often one has to pay the fixed fee, thus “wasting” gas that could otherwise be used for calldata. As a result, this limit can cause the maximum block size to be reduced by ~0.07 MB. Importantly, the client limits only impact the broadcasting of transactions and do not affect blocks that have already been confirmed.

Let’s focus on the gas limit per block first:

impact_block_gas_limit1200×400 17.1 KB

The most straightforward and apparent way to scale a blockchain like Ethereum is increasing the block gas limit. A higher limit means more space for data. However, this also comes with larger blocks that everyone running a full node needs to propagate and download.As visible in the chart above, the “worst-case” block size increases more or less linearly with the block gas limit. Those limits can be reached by creating blocks that use as many non-zero byte calldata transaction of maximum size.

Next, let’s shift our focus to the second point - Ethereum’s pricing mechanism.More specifically, we look at the costs for non-zero byte calldata that is currently set to 16 gas:

impact_calldata_price1200×400 20.4 KB

As we can see in the above chart, increasing the costs for non-zero calldata leads to decreasing block sizes. On the other hand, reducing the costs to, e.g. 8 gas per byte, doubles the size of worst-case blocks. This is very intuitive as halving the price allows to put double the amount of data into a block.

What about EIP-4844 (Proto-Danksharding)?

I won’t cover the details of 4844 here as there exists great documentation on eip4844.com 1, but simply speaking, EIP-4844 introduces “sidecars” that are named “blobs” with each blob carrying ~125kb of data. Similar to EIP-1559, there exists a “target” which determines the targeted number of blobs available. With the Dencun hardfork the target is set to 3 blobs with a maximum set to 6 blobs per block.Importantly, blobs come with their own fee market, creating a so-called multidimensional fee market 1. This means that blobs don’t have to compete with standard transactions but are decoupled from the EIP-1559 fees.

So far, so good. Let’s see how this upgrade affects the average block size of Ethereum.

blobs1200×400 64 KB

As of today, the average block size of beacon chain blocks after employing snappy compression is around 125 KB. With 4844, we add another 375 KB to each block, thus 4x’ing the current avg. block size. By reaching the maximum number of blobs, we essentially increase the current block size by sevenfold.

The worst-case block increases from ~1.77 MB to ~2.5 MB. This estimation does not take into account the CL parts of a block. Nonetheless, in the event of a DoS attack, we must be prepared to deal with such maximum size blocks.

Conclusion

Finally, increasing the current block gas limit requires thorough research and analysis before implementation. While sophisticated entities like Coinbase, Binance, Kraken, or Lido Node Operators might manage block gas limits over 40 million, solo stakers could struggle.

Thus, such decisions must be well-considered to make sure we do not hurt decentralization.

In the end, it’s rather easy to build something that is as scalable as Facebook but what matters is to not lose the property that most of us signed up for: decentralization.

Comments

All Comments

Recommended for you

  • The US FDIC plans to establish an application process for regulated institutions seeking to issue payment stablecoins.

    U.S. Federal Deposit Insurance Corporation (FDIC) announced the approval of a proposed rule to establish an application process for institutions seeking to issue payment stablecoins and regulated by the FDIC. A 60-day public comment period has now been opened. It is reported that this is the first formal rulemaking proposal following the passage of the "GENIUS Act" - the "American Stablecoin Innovation Act."

  • BTC breaks through $88,000

     market shows BTC breaking through $88,000, currently at $88,002.21, a 24-hour increase of 1.34%. The market is highly volatile, please manage your risk accordingly.

  • Bitwise believes 2026 will be a bull market for cryptocurrencies and has released ten predictions.

    Bitwise believes 2026 will be a year of a cryptocurrency bull market. From institutional adoption to regulatory progress, the current positive trends in cryptocurrency are too strong to be suppressed for a long time. Here are Bitwise's top ten predictions for the coming year.

  • China Properties Investment plans to purchase and hold BNB as a strategic reserve asset.

    China Real Estate Investment (00736) announced that in order to promote the diversification of the company's asset allocation and seize the opportunities of digital economy development, the company has resolved to use its own funds to purchase and hold BNB (Binance Coin) and other suitable digital assets in the open market, under the premise of complying with relevant laws, regulations, and risk control, as the company's strategic reserve assets. The company is optimistic about the long-term development prospects of the digital asset industry and has full confidence in the operating entity behind BNB, its technology research and development, ecological layout, and industry competitiveness, recognizing its long-term development potential and value growth space in the blockchain field.

  • Payment infrastructure company Speed1 raises $8 million in funding, led by Tether.

    payment infrastructure company Speed1 announced the completion of an $8 million financing round, led by Tether and participated by Ego Death Capital. The company is committed to building instant global settlement channels using the Bitcoin Lightning Network and stablecoins.

  • Visa begins supporting US financial institutions to settle transactions using USDC on Solana.

    Visa has started supporting U.S. financial institutions to use USDC on Solana for transaction settlements. Cross River Bank and Lead Bank are the first institutions to use this service. As a partner of the Circle Arc blockchain, Visa will also provide support after Arc goes live.

  • Bank of America survey: Kevin Hassett expected to lead the Federal Reserve

     Bank of America's December Global Fund Manager Survey shows that most investors expect U.S. President Trump to nominate White House economic advisor Kevin Hassett as the next Federal Reserve Chair. About 69% expect Hassett to be nominated, while only 4% mentioned Federal Reserve Governor Christopher Waller, and another 4% expect former Fed Governor Kevin Warsh. The survey was conducted before Trump told the media he preferred Hassett or Warsh to lead the Fed. Current Federal Reserve Chair Jerome Powell's term will end in May.

  • Singapore-based digital trade platform Olea completes $30 million Series A funding round.

    Singapore digital trade platform Olea has completed a $30 million Series A funding round, with investors including Banco Bilbao Vizcaya Argentaria (BBVA), XDC Network, theDOCK, and SC Ventures, a subsidiary of Standard Chartered Bank. The funds will be used to accelerate the deployment of AI and Web3 solutions in high-growth markets, strengthening embedded finance, risk analysis, and other products. Since its establishment in 2022, the Olea platform has been licensed by the Monetary Authority of Singapore (MAS) CMS and has provided over $3 billion in financing to more than 1,000 enterprises across more than 70 trade corridors.

  • BTC breaks through $87,000

    market shows BTC breaking through $87,000, currently at $86,986.63, with a 24-hour decline of 3.19%. The market is highly volatile, please manage your risk accordingly.

  • MEXC now supports USD1 (AB Core network).

    On December 16, AB DAO announced that MEXC has officially supported the deposit of USD1 (World Liberty Financial USD) on the AB Core network, and withdrawals will be opened after liquidity meets the platform requirements, further promoting the cross-platform circulation and use of USD1 within the AB ecosystem.