Step 5 of 5: This tutorial is designed to be followed step-by-step.
Each step builds on the previous one, and this is the last part of the tutorial.
Automated Setup AvailableFor a complete working setup with all components including automated prestate generation, check out the automated approach in the code directory.
op-challenger
. The challenger is a critical fault proofs component that monitors dispute games and challenges invalid claims to protect your OP Stack chain.
See the OP-Challenger explainer for a general overview of this fault proofs feature.
The challenger is responsible for:
- Monitoring dispute games created by the fault proof system
- Challenging invalid claims in dispute games
- Defending valid state transitions
- Resolving games when possible
Prerequisites
Essential requirements
Before configuring your challenger, complete the following steps:1
Deploy OP Stack chain with fault proofs enabled
2
Set up required infrastructure access
- L1 RPC endpoint (Ethereum, Sepolia, etc.)
- L1 Beacon node endpoint (for blob access)
3
Prepare configuration files
prestate.json
- The absolute prestate file generated in step 1rollup.json
- Rollup configuration file from theop-deployer
guide
Software installation
For challenger deployment, we recommend using Docker as it provides a consistent and isolated environment. Building from source is also available for more advanced users.- Use docker
- Build from source
Docker Setup
The Docker setup provides a containerized environment for running the challenger. This method uses the official Docker image that includes embeddedop-program
server and Cannon executable.1
Create challenger directory
2
Create environment file
OP Stack Standard VariablesThe challenger uses OP Stack standard environment variables following the OP Stack conventions. These are prefixed with
OP_CHALLENGER_
for challenger-specific settings.YOUR_ACTUAL_*
) with your real configuration values.3
Set up Docker Compose
Create a
docker-compose.yml
file that defines the challenger service. The file mounts several important files:prestate-proof-mt64.json
and${PRESTATE_HASH}.bin.gz
: Prestate files required for dispute games (the PRESTATE_HASH comes from runningmake reproducible-prestate
), replacePRESTATE_HASH
with the actual hash
4
Launch the challenger
Start the challenger service and monitor its logs:
Monitoring with op-dispute-mon
Consider runningop-dispute-mon
for enhanced security monitoring:
- Provides visibility into all game statuses for the last 28 days
- Essential for production challenger deployments
- Create Grafana dashboards using: Download the Dispute Monitor JSON
Congratulations
You’ve successfully completed the entire L2 rollup testnet tutorial! Your rollup is now fully operational with all components running:- op-deployer - L1 contracts deployed
- Sequencer - Processing transactions
- Batcher - Publishing data to L1
- Proposer - Submitting state roots
- Challenger - Monitoring disputes
Connect your wallet to your chain
You now have a fully functioning OP Stack Rollup with a Sequencer node running onhttp://localhost:8545
. You can connect your wallet to this chain the same way you’d connect your wallet to any other EVM chain.
Get ETH on your chain
Once you’ve connected your wallet, you’ll probably notice that you don’t have any ETH to pay for gas on your chain. The easiest way to deposit Sepolia ETH into your chain is to send ETH directly to theL1StandardBridge
contract.
Get the L1StandardBridge address
TheL1StandardBridge
proxy address can be found in your deployment state file. To get it, run:
L1StandardBridge
proxy address that you should use for deposits. Make sure to use the proxy address, not the implementation address.
Deposit ETH to your L2
Once you have theL1StandardBridge
address, send a small amount of Sepolia ETH (0.1 or less) to that address from the wallet you want to use on L2.
This will trigger a deposit that will mint ETH into your wallet on L2.
It may take up to 5 minutes for the ETH to appear in your wallet on L2.
This delay is due to the time needed for the deposit transaction to be processed and finalized.
See your rollup in action
You can interact with your Rollup the same way you’d interact with any other EVM chain. Send some transactions, deploy some contracts, and see what happens!Need Help?
- Community Support: Join the Optimism Discord
- OP Challenger Explainer: Fault Proofs Overview
- Technical Specs: Honest Challenger Specification
- Developer Support: GitHub Discussions