Published on

Improving reth with our free Ethereum rpc service

Authors
We monetize orderflow.
👋 merkle specializes in protecting and monetizing orderflow in that order. We guarantee best-in-class inclusion & ordering while paying the most for your orderflow.

At merkle, we consume hundreds of millions of RPC requests every month just to service our products (Private mempool, Transaction network). Using regular RPC providers such as Alchemy made our bill go through the roof. It became clear that in order to scale, we needed to run our own nodes. But because we are a small team, we needed to find a way to run nodes that are cheap, fast and reliable.

What is reth

reth is a new node, developed by engineers at Paradigm, the investment firm. Its features include:

  • Must faster sync time
  • Much lower disk usage for archive node (~3TB as of today)
  • Much higher RPC concurrent requests capacity

What is eth.merkle.io

eth.merkle.io is our 100% free, unlimited rpc service, backed by reth nodes. Our goal is to provide a free, reliable and fast RPC service to the community while helping the reth team fix performance issues.

How we setup reth

Running reth in production is somewhat easy, but there are a few things to keep in mind:

  • reth is still in beta, so expect some bugs
  • reth might have some discrepancies with response types
  • reth might crash (although it has never happened to us)

Just to be safe, we have setup geth nodes as backups, if the reth nodes ever crash.

reth performance

The following results come from production data from eth.merkle.io and data from internal usage. The results shown here are response times as measured by our custom load balancer.

Most of the rpc methods in reth have similar response times as geth, but there are a few exceptions.

eth_getGasPrice

When we started running reth, we noticed that eth_getGasPrice was unusually slow:

reth eth call

This issue was reported to the reth team and promptly fixed in #5050. Leading to similar response times as geth:

reth eth call

eth_getLogs

We also noticed that eth_getLogs was unusually slow:

reth eth call

Unfortunately, this issue is not solved yet, as it requires the implementation of log indexing #4167.

Conclusion

reth is a great node, but it's still in beta and not a good fit if you are heavily reliant on eth_getLogs. We are continuing to help the reth team fix performance issue. If you want to help, plug eth.merkle.io in your dapp/wallet and we'll report any issues we find to the reth team.

Work with us!
We are looking for talented enginners with Rust experience. Bonus points if you have ever contributed to Reth or built an MEV bot in any language. We are also hiring for Senior Frontend Engineers, Senior Backend Engineers, Data Engineers & more.
Sign up
Snipe API
Add best-in-class sniping into your Bot or Non-custodial Wallet.
Sign up