Skip to content

flashbots/op-rbuilder

op-rbuilder

CI status

op-rbuilder is a Rust-based block builder designed to build blocks for the Optimism stack.

Running op-rbuilder

To run op-rbuilder with the op-stack, you need:

  • CL node to sync the op-rbuilder with the canonical chain
  • Sequencer with the rollup-boost setup

To run the op-rbuilder, run:

cargo run -p op-rbuilder --bin op-rbuilder -- node \
    --chain /path/to/chain-config.json \
    --http \
    --authrpc.port 9551 \
    --authrpc.jwtsecret /path/to/jwt.hex

To build the op-rbuilder, run:

cargo build -p op-rbuilder --bin op-rbuilder

Flashblocks

To run op-rbuilder with flashblocks:

cargo run -p op-rbuilder --bin op-rbuilder -- node \
    --chain /path/to/chain-config.json \
    --http \
    --authrpc.port 9551 \
    --authrpc.jwtsecret /path/to/jwt.hex \
    --flashblocks.enabled \
    --flashblocks.port 1111 \ # port to bind ws that provides flashblocks 
    --flashblocks.addr 127.0.0.1 # address to bind the ws that provides flashblocks

Flashblocks Number Contract

To enable builder tranctions to the flashblocks number contract for contracts to integrate with flashblocks onchain, specify the address in the CLI args:

cargo run -p op-rbuilder --bin op-rbuilder -- node \
    --chain /path/to/chain-config.json \
    --http \
    --authrpc.port 9551 \
    --authrpc.jwtsecret /path/to/jwt.hex \
    --flashblocks.enabled \
    --flashblocks.number-contract-address 0xFlashblocksNumberAddress

This will increment the flashblock number before the start of every flashblock and replace the builder tx at the end of the block.

Flashtestations

To run op-rbuilder with flashtestations:

cargo run -p op-rbuilder --bin op-rbuilder -- node \
    --chain /path/to/chain-config.json \
    --http \
    --authrpc.port 9551 \
    --authrpc.jwtsecret /path/to/jwt.hex \
    --flashtestations.enabled \
    --flashtestations.rpc-url your-rpc-url \ # rpc to submit the attestation transaction to
    --flashtestations.funding-amount 0.01 \ # amount in ETH to fund the TEE generated key
    --flashtestations.funding-key secret-key \ # funding key for the TEE key
    --flashtestations.registry-address 0xFlashtestationsRegistryAddress \
    --flashtestations.builder-policy-address 0xBuilderPolicyAddress

Note that --rollup.builder-secret-key must be set and funded in order for the flashtestations key to be funded and submit the attestation on-chain.

Observability

To verify whether a builder block has landed on-chain, you can add the --rollup.builder-secret-key flag or BUILDER_SECRET_KEY environment variable. This will add an additional transaction to the end of the block from the builder key. The transaction will have Block Number: {} in the input data as a transfer to the zero address. Ensure that the key has sufficient balance to pay for the transaction at the end of the block.

To enable metrics, set the --metrics flag like in reth which will expose reth metrics in addition to op-rbuilder metrics. op-rbuilder exposes on-chain metrics via reth execution extensions such as the number of blocks landed and builder balance. Note that the accuracy of the on-chain metrics will be dependent on the sync status of the builder node. There are also additional block building metrics such as:

  • Block building latency
  • State root calculation latency
  • Transaction fetch latency
  • Transaction simulation latency
  • Number of transactions included in the built block

To see the full list of op-rbuilder metrics, see src/metrics.rs.

Default debug level trace logs can be found at:

  • ~/.cache/op-rbuilder/logs on Linux
  • ~/Library/Caches/op-rbuilder/logs on macOS
  • %localAppData%/op-rbuilder/logs on Windows

Integration Testing

op-rbuilder has an integration test framework that runs the builder against mock engine api payloads and ensures that the builder produces valid blocks.

You can run the tests using the command

just run-tests

or the following sequence:

# Ensure you have op-reth installed in your path,
# you can download it with the command below and move it to a location in your path
./scripts/ci/download-op-reth.sh

# Generate a genesis file
cargo run -p op-rbuilder --features="testing" --bin tester -- genesis --output genesis.json

# Build the op-rbuilder binary
cargo build -p op-rbuilder --bin op-rbuilder

# Run the integration tests
cargo test --package op-rbuilder --lib

Local Devnet

  1. Clone flashbots/builder-playground and start an OPStack chain.
git clone https://github.com/flashbots/builder-playground.git
cd builder-playground
go run main.go cook opstack --external-builder http://host.docker.internal:4444
  1. Remove any existing reth chain db. The following are the default data directories:
  • Linux: $XDG_DATA_HOME/reth/ or $HOME/.local/share/reth/
  • Windows: {FOLDERID_RoamingAppData}/reth/
  • macOS: $HOME/Library/Application Support/reth/
  1. Run op-rbuilder in the rbuilder repo on port 4444:
cargo run -p op-rbuilder --bin op-rbuilder -- node \
    --chain $HOME/.playground/devnet/l2-genesis.json \
    --http --http.port 2222 \
    --authrpc.addr 0.0.0.0 --authrpc.port 4444 --authrpc.jwtsecret $HOME/.playground/devnet/jwtsecret \
    --port 30333 --disable-discovery \
    --metrics 127.0.0.1:9011 \
    --rollup.builder-secret-key ac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80 \
    --trusted-peers enode://79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8@127.0.0.1:30304
  1. Run contender:
cargo run -- spam --tps 10 -r http://localhost:2222 --optimism --min-balance 0.14

And you should start to see blocks being built and landed on-chain with contender transactions.

Builder playground

You can quickly spin up an op-stack devnet using builder-playground. The quickest workflow to get op-stack running against your local op-rbuilder instance is:

  1. Check out the builder playground repo
git clone [email protected]:flashbots/builder-playground.git
  1. In the builder-playgound spin up an l2 opstack setup specifying that it should use an external block builder:
go run main.go cook opstack --external-builder http://host.docker.internal:4444
  1. Run rbuilder in playground mode:
cargo run --bin op-rbuilder -- node --builder.playground

You could also run it using:

just run-playground

This will automatically try to detect all settings and ports from the currently running playground. Sometimes you might need to clean up the builder-playground state between runs. This can be done using:

rm -rf ~/.local/share/reth
sudo rm -rf ~/.playground

Running GitHub actions locally

To verify that CI will allow your PR to be merged before sending it please make sure that our GitHub checks.yaml action passes locall by calling:

act -W .github/workflows/checks.yaml

More instructions on installing and configuring act can be found on their website.

Known issues

  • Running actions locally require a Github Token. You can generate one by following instructions on Github Docs. After generating a token you will need to pass it to act either through the command line using -s GITHUB_TOKEN=<your token> or by adding it to the ~/.config/act/actrc file.
  • You might get an error about missing or incompatible warp-ubuntu-latest-x64-32x platform. This can be mitigated by adding -P warp-ubuntu-latest-x64-32x=ghcr.io/catthehacker/ubuntu:act-latest on the command line when calling act or appending this flag to ~/.config/act/actrc

About

No description, website, or topics provided.

Resources

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT

Contributing

Security policy

Stars

Watchers

Forks

Packages

 
 
 

Contributors 25