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

  • Iran Plans Access and Fee System for Vessels in the Strait of Hormuz

    On March 30, according to CCTV, Aladdin Boroujerdi, a member of the National Security and Foreign Policy Commission of the Iranian Islamic Parliament, stated that in light of the current international security situation and external threats, Iran is seriously considering withdrawing from the Treaty on the Non-Proliferation of Nuclear Weapons. Additionally, Iran plans to implement stricter access and fee systems for vessels passing through the Strait of Hormuz. Boroujerdi also mentioned that Iran currently has complete control over this strategic waterway. He revealed that Iran intends to establish a new management system for the strait, modeled after Turkey's management of the Bosphorus and Egypt's management of the Suez Canal, requiring vessels passing through the strait to obtain permission from Iran and pay corresponding transit and service fees. (Dongxin News Agency)

  • Ethereum Foundation Stakes $46.2 Million in ETH

    On March 30, Arkham monitoring reported that the Ethereum Foundation has just staked $46.2 million worth of ETH, marking the largest amount of ETH staked in the foundation's history.

  • US Special Forces May Participate in Island Seizure or Iran Nuclear Tasks

    On March 30, according to a report by the New York Times on March 29, two U.S. military officials revealed that hundreds of U.S. special operations personnel have arrived in the Middle East, including Army Rangers and Navy SEALs, to provide 'more options' for U.S. military actions against Iran. The report states that these special operations forces have not yet been assigned specific tasks, but as professional ground combat units, they may be involved in operations related to the Strait of Hormuz, Hark Island, or Iran's nuclear facilities. (CCTV International News)

  • FTSE China A50 Index Futures Turn Positive

    On March 30, FTSE China A50 Index futures turned positive after previously dropping more than 1%. (Jin Shi)

  • Trump Claims Iran Has Agreed to Most of the '15-Point Plan'

    On March 30, CNN reported that U.S. President Trump stated that Iran has agreed to most of the content in the ceasefire '15-point plan'. (Xinhua News Agency)

  • BTC Surpasses $67,000

    Market data shows that BTC has surpassed $67,000, currently priced at $67,017.45, with a 24-hour increase of 0.44%. The market is experiencing significant fluctuations, so please ensure proper risk management.

  • Trump: US Will Act Swiftly if Iran Charges Fees in Strait of Hormuz

    On March 30, when asked about Iran's plans to charge fees in the Strait of Hormuz, US President Trump stated that he needed to confirm the validity of this information, but that the US could terminate such actions very quickly. "We can complete this task in two minutes. We can do it so swiftly that you would feel dizzy," he said. He noted that Saudi Arabia, Qatar, the UAE, and Bahrain are retaliating against Iran. "I was very surprised by their attack. But once attacked, they retaliated effectively. We have very strong communication, but people from all these countries say they have been fighting all along," he added. (Jinshi)

  • A-shares Trading Volume Exceeds 500 Billion Yuan

    On March 30, the trading volume of the Shanghai and Shenzhen stock exchanges exceeded 500 billion yuan, an increase of 86.4 billion yuan compared to the same time the previous day. (Jin Shi)

  • Trump: Iran Has Allowed 20 Tankers to Pass Through the Strait of Hormuz

    On March 30, U.S. President Trump stated on the 29th that Iran allowed 10 tankers flying the Pakistani flag to pass through the Strait of Hormuz last week, and the number has now increased to 20. He told the Financial Times, 'These tankers have set sail and are heading straight through the center of the strait.' The decision was approved by Iran's Islamic Parliament Speaker Ghalibaf. (Xinhua)

  • China's AI Model Usage Surges Nearly 34% Month-on-Month, Outpacing the U.S. for Four Consecutive Weeks

    On March 30, according to the latest data from institutions, the total global usage of AI large models reached 22.7 trillion tokens last week, reflecting an 11.2% month-on-month increase. Among the listed AI models, the weekly usage of Chinese AI models rose to 9.857 trillion tokens, marking a 33.94% increase from the previous week; the weekly usage of U.S. AI models was 3.007 trillion tokens, with a month-on-month growth of 1.79%. The weekly usage of Chinese AI models has increased for four consecutive weeks, consistently surpassing that of the U.S. In the past week, the top four global usage rankings were all occupied by Chinese AI models. Xiaomi's MiMo-V2-Pro maintained its top position with a weekly usage of 3.96 trillion tokens; Step 3.5 Flash (free) ranked second with a weekly usage of 1.49 trillion tokens; MiniMax M2.7 entered the rankings at third place with a weekly usage of 1.29 trillion tokens; and DeepSeek V3.2 ranked fourth with a weekly usage of 1.24 trillion tokens, reflecting an 8.7% increase. Meanwhile, MiniMax M2.5, which ranked third the previous week, fell to ninth place, nearly dropping out of the rankings, with a weekly usage of 0.909 trillion tokens, down 30% month-on-month. (Dongxin News Agency)