This mempool implementation is experimental and under active development. It is intended for testing and evaluation purposes. Use in production environments is not recommended without thorough testing and risk assessment.
Please report issues and submit feedback to help improve stability.
Overview
The EVM mempool is responsible for managing both EVM and Cosmos transactions in a unified pool, enabling Ethereum-compatible transaction flows including out-of-order transactions and nonce gap handling. It serves as a replacement for the default CometBFT FIFO mempool to support Ethereum tooling expectations while maintaining Cosmos SDK compatibility.Usage Examples
The EVM mempool enables seamless interaction with Ethereum tooling and deployment scripts that send multiple transactions in quick succession.Complex Contract Deployments
DeFi protocols like Uniswap deploy multiple interdependent contracts in rapid succession. With the EVM mempool, these deployment scripts work without modification:Batch Transaction Submission
Transaction Replacement
Transaction Flow
1. Transaction Submission
Users or other nodes submit transactions to the chain via JSON-RPC or P2P.2. CometBFT Reception
CometBFT receives the transactions and validates them in the app using CheckTx.3. CheckTx Routing
The CheckTx handler processes transactions with special handling for nonce gaps (source): Success Path - Valid transactions with correct nonces pass through to the Comet mempool for broadcast. Nonce Gap Detection - Transactions with future nonces are intercepted and queued locally:- Insufficient fees: Transactions with
GasFeeCap < BaseFee
fail withErrInsufficientFee
- Insufficient balance: Transactions exceeding account balance
- Invalid signature: Malformed or invalid transaction signatures
4. Comet Mempool Addition
Successfully validated transactions are added to the Comet mempool (FIFO).5. P2P Broadcast
Transactions in the Comet mempool are broadcast to other peers across the network.6. Block Building
When a validator is selected to propose a block, ProcessProposal uses the mempool to build blocks:- Sorts transactions by account (fee priority) and nonce
- Pulls from both local queue and public pool
- Replaces lower-fee duplicates with higher-fee versions
7. Automatic Promotion
The node periodically scans the local queue and promotes transactions when:- Nonce gaps are filled (either in mempool or from on-chain state)
- Promoted transactions are re-broadcast to the network
Transaction Lifecycle
Architecture

Problem Statement
CometBFT rejects transactions with:- Nonce gaps (non-sequential nonces)
- Out-of-order batches (common in deployment scripts)
Solution Architecture
To improve DevEx, a tiered approach was implemented: a local transaction pool handles queuing nonce-gapped transactions, upgrading transactions to CometBFT mempool which allows them to be gossipped to network peers and be included in blocks. This helps reduce network spam/DOS exposure while also enabling proper EVM transaction semantics. The two-tiered approach:- Local queue: Stores gapped transactions without network propagation, preventing invalid transaction gossip
- Public mempool: Contains only valid transactions, maintaining consensus integrity
- Automatic promotion: Moves transactions from local to public when gaps fill, ensuring inclusion once conditions are met

Core Components
CheckTx Handler Intercepts nonce gap errors during validation, routes gapped transactions to the local queue, and returns success to maintain compatibility with Ethereum tooling that expects queuing behavior. Only nonce gaps are intercepted - other validation failures (insufficient fees, balance, etc.) are rejected immediately. TxPool Direct port of Ethereum’s transaction pool that manages both pending (executable) and queued (future) transactions. Handles promotion, eviction, and replacement according to Ethereum rules. LegacyPool Stores non-executable transactions with nonce gaps, tracks dependencies between transactions, and automatically promotes them when gaps are filled. The queue contains only transactions waiting for earlier nonces - not transactions with insufficient fees. ExperimentalEVMMempool Unified structure that manages both EVM and Cosmos transaction pools while providing a single interface for transaction insertion, selection, and removal.Transaction States
Queued (Local Storage):- Nonce gaps: Transactions with nonce > expected nonce
- These are stored locally and promoted when gaps fill
- Insufficient fees:
GasFeeCap < BaseFee
- Insufficient balance: Transaction cost exceeds account balance
- Invalid signature: Malformed or improperly signed transactions
- Gas limit exceeded: Transactions exceeding block gas limit
API Reference
The mempool exposes Ethereum-compatible RPC methods for querying transaction pool state. See the JSON-RPC Methods documentation for detailed API reference:txpool_status
: Get pending and queued transaction countstxpool_content
: View all transactions in the pooltxpool_contentFrom
: View transactions from specific addressestxpool_inspect
: Get human-readable transaction summaries
Integration
For chain developers looking to integrate the mempool into their Cosmos SDK chain, see the EVM Mempool Integration Guide for complete setup instructions.
State Management
The mempool maintains transaction state through the unifiedExperimentalEVMMempool
structure, which manages separate pools for EVM and Cosmos transactions while providing a single interface. This experimental implementation handles fee-based prioritization, nonce sequencing, and transaction verification through an integrated ante handler.
Testing
The mempool behavior can be verified using the test scripts provided in the cosmos/evm repository. Thetests/systemtests/Counter/script/SimpleSends.s.sol
script demonstrates typical Ethereum tooling behavior - it sends 10 sequential transactions in a batch, which naturally arrive out of order and create nonce gaps.