Base is a secure, low-cost, developer-friendly Ethereum L2 built on Optimism's OP Stack. This repository contains Docker builds to run your own node on the Base network.
-
Ensure you have an Ethereum L1 full node RPC available
-
Choose your network:
- For mainnet: Use
.env.mainnet
- For testnet: Use
.env.sepolia
- For mainnet: Use
-
Configure your L1 endpoints in the appropriate
.env
file:OP_NODE_L1_ETH_RPC=<your-preferred-l1-rpc> OP_NODE_L1_BEACON=<your-preferred-l1-beacon> OP_NODE_L1_BEACON_ARCHIVER=<your-preferred-l1-beacon-archiver>
-
Start the node:
# For mainnet (default): docker compose up --build # For testnet: NETWORK_ENV=.env.sepolia docker compose up --build # To use a specific client (optional): CLIENT=reth docker compose up --build # For testnet with a specific client: NETWORK_ENV=.env.sepolia CLIENT=reth docker compose up --build
geth
(default)reth
nethermind
- Modern Multicore CPU
- 32GB RAM (64GB Recommended)
- NVMe SSD drive
- Storage: (2 * current chain size + snapshot size + 20% buffer (to accomodate future growth)
- Docker and Docker Compose
The following are the hardware specifications we use in production:
- Instance: AWS i4i.12xlarge
- Storage: RAID 0 of all local NVMe drives (
/dev/nvme*
) - Filesystem: ext4
- Instance: AWS i7ie.6xlarge
- Storage: RAID 0 of all local NVMe drives (
/dev/nvme*
) - Filesystem: ext4
[!NOTE]
To run the node using a supported client, you can use the following command:
CLIENT=supported_client docker compose up --build
Supported clients:
- geth
- reth (with Flashblocks support option, see Reth Node README)
- nethermind
- L1 Configuration:
OP_NODE_L1_ETH_RPC
: Your Ethereum L1 node RPC endpointOP_NODE_L1_BEACON
: Your L1 beacon node endpointOP_NODE_L1_BEACON_ARCHIVER
: Your L1 beacon archiver endpointOP_NODE_L1_RPC_KIND
: The type of RPC provider being used (default: "debug_geth"). Supported values:alchemy
: Alchemy RPC providerquicknode
: QuickNode RPC providerinfura
: Infura RPC providerparity
: Parity RPC providernethermind
: Nethermind RPC providerdebug_geth
: Debug Geth RPC providererigon
: Erigon RPC providerbasic
: Basic RPC provider (standard receipt fetching only)any
: Any available RPC methodstandard
: Standard RPC methods including newer optimized methods
- Mainnet:
RETH_CHAIN=base
OP_NODE_NETWORK=base-mainnet
- Sequencer:
https://mainnet-sequencer.base.org
- Cache Settings:
GETH_CACHE="20480"
(20GB)GETH_CACHE_DATABASE="20"
(4GB)GETH_CACHE_GC="12"
GETH_CACHE_SNAPSHOT="24"
GETH_CACHE_TRIE="44"
- EthStats Monitoring (uncomment to enable)
- Trusted RPC Mode (uncomment to enable)
- Snap Sync (experimental)
For full configuration options, see the .env.mainnet
file.
Snapshots are available to help you sync your node more quickly. See docs.base.org for links and more details on how to restore from a snapshot.
Network | Status |
---|---|
Mainnet | ✅ |
Testnet | ✅ |
For support please join our Discord post in 🛠|node-operators
. You can alternatively open a new GitHub issue.
THE NODE SOFTWARE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. We make no guarantees about asset protection or security. Usage is subject to applicable laws and regulations.
For more information, visit docs.base.org.