アービトラージBotの構築から運用までの具体的な手順
① 環境構築
- 必要なもの
項目 説明
OS Windows 11(WSL2推奨) or Linux(Ubuntu 20.04)
プログラミング言語 TypeScript(Node.js) or Python(Web3.py)
取引所API Bitget, MEXC, Hyperliquid, Binance, Uniswap, 1inch
ウォレット MetaMask(Ethereum, BSC, Arbitrum対応)
開発環境 VS Code(またはJetBrains系)、Docker、Git
データ取得 WebSocket(リアルタイムデータ)、REST API
サーバー(推奨) AWS, Vultr, Hetzner, GCP(常時稼働用)
- ソフトウェアのインストール
Windows 11 + WSL2環境
1. WSL2 & Ubuntuのインストール
wsl --install -d Ubuntu-20.04
2. Node.jsとTypeScriptをインストール
curl -fsSL https://deb.nodesource.com/setup_18.x | sudo -E bash -
sudo apt install -y nodejs
npm install -g typescript ts-node pm2
3. Python環境(代替案)
sudo apt update && sudo apt install -y python3-pip
pip install web3 requests pandas ccxt
② 取引所APIの設定
- APIキーの取得
各取引所(Bitget, MEXC, Hyperliquid, Binance, Uniswap)でAPIキーを発行。
• 現物 & 先物取引が必要なら「Trade」権限を付与
• 出金APIはセキュリティ上オフ
- .env にAPIキーを保存
BITGET_API_KEY=your_bitget_api_key
BITGET_SECRET_KEY=your_bitget_secret
MEXC_API_KEY=your_mexc_api_key
MEXC_SECRET_KEY=your_mexc_secret
HYPERLIQUID_API_KEY=your_hyperliquid_api_key
HYPERLIQUID_SECRET_KEY=your_hyperliquid_secret
RPC_URL=https://arb1.arbitrum.io/rpc
PRIVATE_KEY=your_wallet_private_key
③ コードの実装
- CEX間アービトラージBot(Bitget × MEXC)
import axios from "axios";
import dotenv from "dotenv";
dotenv.config();
const BITGET_API = process.env.BITGET_API_KEY;
const BITGET_SECRET = process.env.BITGET_SECRET_KEY;
const MEXC_API = process.env.MEXC_API_KEY;
const MEXC_SECRET = process.env.MEXC_SECRET_KEY;
// 価格取得関数
async function getPrice(exchange: string, symbol: string) {
try {
let url = "";
if (exchange === "bitget") {
url = https://api.bitget.com/api/spot/v1/market/ticker?symbol=${symbol}
;
} else if (exchange === "mexc") {
url = https://api.mexc.com/api/v3/ticker/price?symbol=${symbol}
;
}
const response = await axios.get(url);
return parseFloat(response.data.data.last);
} catch (error) {
console.error(価格取得エラー: ${exchange}
, error);
return null;
}
}
// アービトラージ実行
async function arbitrage() {
const bitgetPrice = await getPrice("bitget", "BTCUSDT");
const mexcPrice = await getPrice("mexc", "BTCUSDT");
if (!bitgetPrice || !mexcPrice) return;
const spread = mexcPrice - bitgetPrice;
console.log(Bitget: ${bitgetPrice}, MEXC: ${mexcPrice}, 差額: ${spread}
);
if (spread > 50) {
console.log("MEXCで売り、Bitgetで買いのアービトラージ実行");
// APIを使って実際に売買処理
} else if (spread < -50) {
console.log("MEXCで買い、Bitgetで売りのアービトラージ実行");
// APIを使って実際に売買処理
} else {
console.log("アービトラージ機会なし");
}
}
// 5秒ごとにアービトラージチェック
setInterval(arbitrage, 5000);
④ サーバーでBotを24時間稼働
1. PM2を使う(推奨)
pm2 start arbitrage.ts --name arbitrage-bot --interpreter ts-node
pm2 save
pm2 startup
2. Dockerで動かす(高度な運用)
FROM node:18
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
CMD ["ts-node", "arbitrage.ts"]
docker build -t arbitrage-bot .
docker run -d --name arbitrage-bot arbitrage-bot
⑤ 資金管理
- 初期資金の分配
取引所 用途 初期資金割合
Bitget BTC/USDTのアービトラージ用 40%
MEXC 価格差発生時の対処 40%
ウォレット(MetaMask) DEXアービトラージ用 20%
-
リスク管理
• 1回の取引で資金の10%以下を使用
• ストップロス機能をBotに組み込む
• スリッページ対策で価格乖離が大きい場合は取引しない -
収益の引き出し
• 1日ごとに利益の一部をUSDTに変換
• 週ごとにウォレット & 銀行に分配
• 税金対策(記録を自動保存)
⑥ Botの最適化
- 取引履歴をログに記録
import fs from "fs";
function logTrade(data: string) {
fs.appendFileSync("trade_log.txt", ${new Date().toISOString()} - ${data}\n
);
}
- 手数料を考慮
手数料が低い取引所を優先する
- 高速化
WebSocketを使う
import WebSocket from "ws";
const ws = new WebSocket("wss://api.bitget.com/ws/market");
ws.on("message", (data) => {
console.log("リアルタイムデータ:", JSON.parse(data.toString()));
});
まとめ
✅ 環境構築(Node.js, TypeScript, APIキー設定)
✅ Botの実装(CEXアービトラージ)
✅ サーバー運用(PM2, Docker)
✅ 資金管理(分配 & リスク管理)
✅ 最適化(手数料対策, WebSocket対応)
この方法で安定したアービトラージ運用が可能!
あとは継続的に改善しながら運用すれば利益を最大化できる。