⚠️Blast API (blastapi.io) ends Oct 31. Migrate to Dwellir and skip Alchemy's expensive compute units.
Switch Today β†’
Skip to main content

Manta Pacific - EVM Network

Manta Pacific RPC
With Dwellir, you get access to our global Manta Pacific network which always routes your API requests to the nearest available location, ensuring low latency and the fastest speeds.

Get your API key β†’

Why Build on Manta Pacific?​

Focus on what matters β€” building β€” while Dwellir delivers:

  • High‑availability RPC with global anycast routing and low latency
  • Full Ethereum JSON‑RPC coverage with tracing and debug APIs
  • Consistent, high‑throughput mainnet endpoints
  • Clear rate limits, observability, and an enterprise‑grade SLA

Quick Start with Manta Pacific​

Connect to Manta Pacific in seconds with Dwellir's optimized endpoints:

πŸ”— RPC Endpoints

Manta Pacific Mainnet (Chain ID: 169)Live
https://api-manta-pacific-mainnet.n.dwellir.com/YOUR_API_KEY
βœ“ Archive Nodeβœ“ Trace APIβœ“ Debug APIβœ“ WebSocket

Quick Connect:

curl -X POST https://api-manta-pacific-mainnet.n.dwellir.com/YOUR_API_KEY \
-H "Content-Type: application/json" \
-d '{"jsonrpc":"2.0","method":"eth_blockNumber","params":[],"id":1}'

Installation & Setup​

import { JsonRpcProvider } from 'ethers';

// Connect to Manta Pacific mainnet
const provider = new JsonRpcProvider(
'https://api-manta-pacific-mainnet.n.dwellir.com/YOUR_API_KEY'
);

// Get the latest block
const block = await provider.getBlock('latest');
console.log('Latest block:', block.number);

// Query account balance
const balance = await provider.getBalance('0x...');
console.log('Balance:', balance.toString());

Network Information​

Chain ID

169

Mainnet

RPC Standard

Ethereum

JSON-RPC 2.0

JSON-RPC API Reference​

Manta Pacific supports the standard Ethereum JSON-RPC 2.0 API. Access common methods for blocks, transactions, logs, traces, and debugging.

Available JSON-RPC Methods

πŸ“Š Reading Blockchain Data

Query blocks, transactions, and account states

+

πŸ“€ Sending Transactions

Submit and manage transactions

+

πŸ“ Smart Contract Interaction

Call and interact with smart contracts

+

πŸ”§ Node & Network Info

Query node status and network information

+

Ready to integrate Manta Pacific into your dApp?

Get your API key β†’

Common Integration Patterns​

πŸ”„ Transaction Monitoring​

Monitor pending and confirmed transactions efficiently:

// Watch for transaction confirmation
async function waitForTransaction(txHash) {
const receipt = await provider.waitForTransaction(txHash, 1);
return receipt;
}

πŸ’° Gas Optimization​

Use EIP‑1559 dynamic fees for predictable pricing:

const feeData = await provider.getFeeData();
const tx = {
to: '0x...',
value: 0n,
maxFeePerGas: feeData.maxFeePerGas,
maxPriorityFeePerGas: feeData.maxPriorityFeePerGas,
gasLimit: 21000n,
};

πŸ” Event Filtering​

Efficiently query contract events:

// Query events with automatic retry and pagination
async function getEvents(contract, eventName, fromBlock = 0) {
const filter = contract.filters[eventName]();
const events = [];
const batchSize = 2000; // Manta Pacific recommended batch size

for (let i = fromBlock; i <= currentBlock; i += batchSize) {
const batch = await contract.queryFilter(
filter,
i,
Math.min(i + batchSize - 1, currentBlock)
);
events.push(...batch);
}

return events;
}

Performance Best Practices​

1. Batch Requests​

Combine multiple RPC calls for optimal performance:

const batch = [
{ method: 'eth_blockNumber', params: [] },
{ method: 'eth_gasPrice', params: [] },
{ method: 'eth_getBalance', params: [address, 'latest'] }
];

const results = await provider.send(batch);

2. Connection Pooling​

Reuse provider instances to minimize connection overhead:

// Singleton pattern for provider
class Manta PacificProvider {
static instance = null;

static getInstance() {
if (!this.instance) {
this.instance = new JsonRpcProvider(
'https://api-manta-pacific-mainnet.n.dwellir.com/YOUR_API_KEY'
);
}
return this.instance;
}
}

3. Smart Caching​

Cache immutable data to reduce API calls:

const cache = new Map();

async function getCachedBlockData(blockNumber) {
const key = `block_${blockNumber}`;

if (!cache.has(key)) {
const block = await provider.getBlock(blockNumber);
cache.set(key, block);
}

return cache.get(key);
}

Troubleshooting Common Issues​

Error: "Insufficient funds"​

Always check the account balance against the estimated gas cost:

const balance = await provider.getBalance(address);
const gas = await provider.estimateGas(tx);
const maxCost = gas * (tx.maxFeePerGas ?? 0n) + (tx.value ?? 0n);
if (balance < maxCost) throw new Error('Insufficient funds');

Error: "Transaction underpriced"​

Manta Pacific uses EIP-1559 pricing. Always use dynamic gas pricing:

// Get current fee data
const feeData = await provider.getFeeData();

const tx = {
to: recipient,
value: amount,
maxFeePerGas: feeData.maxFeePerGas,
maxPriorityFeePerGas: feeData.maxPriorityFeePerGas,
gasLimit: 21000n
};

Error: "Rate limit exceeded"​

Implement exponential backoff for resilient applications:

async function callWithRetry(fn, maxRetries = 3) {
for (let i = 0; i < maxRetries; i++) {
try {
return await fn();
} catch (error) {
if (error.code === 429 && i < maxRetries - 1) {
await new Promise(r => setTimeout(r, 2 ** i * 1000));
} else {
throw error;
}
}
}
}

Migration Guide​

From Ethereum Mainnet​

Moving from L1 to Manta Pacific L2 requires minimal changes:

// Before (Ethereum)
const provider = new JsonRpcProvider('https://eth-rpc.example.com');

// After (Manta Pacific)
const provider = new JsonRpcProvider(
'https://api-manta-pacific-mainnet.n.dwellir.com/YOUR_API_KEY'
);

// βœ… Smart contracts work identically
// βœ… Same tooling and libraries
// ⚠️ Different chain ID (169)
// ⚠️ Separate block numbers

Resources & Tools​

Official Resources​

  • Official docs, explorer, and tooling: please refer to the Manta Pacific official channels.

Need Help?​


Start building on Manta Pacific with Dwellir's enterprise-grade RPC infrastructure. Get your API key β†’