evm-grid-bot
🤖 基于 Telegram 的 EVM 链网格交易机器人
📋 项目简介
EVMGridBot 是一个智能的网格交易机器人,通过 Telegram 接口为用户提供 EVM 链(目前支持 BSC 链,扩展到其他 EVM 会非常容易)上代币的自动化网格交易服务。用户只需设置价格区间,机器人将在该区间内自动执行低买高卖的网格交易策略,帮助用户在震荡行情中获利。
💡 提示:此项目专为 EVM 链设计。对于 Solana 链交易,推荐使用 TP Bot,使用教程可供参考。EVMGridBot 的使用方式与 TP Bot 基本相同。
✨ 功能特性
- 🚀 一键部署:无外部依赖,支持快速独立部署
- 🔗 BSC 链支持:专为币安智能链优化的交易体验
- 🎯 智能网格交易:在用户设定的价格区间内自动执行低买高卖策略
- 🔗 稳定币交易:使用 USDT(可配置)交易代币,避免主币波动风险
- 📱 Telegram 集成:通过 Telegram Bot 提供便捷的用户交互界面
- 📊 实时监控:通过 Telegram Bot 实时查询盈亏情况和历史交易
- 🛡️ 安全可靠:本地部署,私钥不离开用户环境
- 💻 易于部署:支持部署在笔记本、家庭电脑、服务器等环境
🏗️ 技术架构
- 开发语言:Go 1.24.1
- 数据库:SQLite3
- 消息接口:Telegram Bot API
- 价格数据:GMGN API/OKX Web3 API
- 架构模式:无外部依赖的单体应用
🚀 快速开始
📌 普通用户提示:如果您不是开发者,可以直接跳过下面的编译步骤,前往 Release 页面 下载最新版本的可执行文件,然后直接查看 配置说明 部分,修改配置文件后即可运行。
环境要求
安装部署
1. 克隆项目
git clone https://github.com/fachebot/evm-grid-bot.git
2. 安装依赖
go mod tidy
3. 构建项目
go build
4. 运行项目
# linux
./evm-grid-bot
# windows
./evm-grid-bot.exe
⚠️ 重要:运行项目前需要创建配置文件,请查看下面的配置说明。
⚙️ 配置说明
在运行项目前,需要创建配置文件 etc/config.yaml,你可以复制 etc/config.yaml.sample 文件到 etc/config.yaml 并进行修改:
# 链配置
Chain:
# 链ID
Id: 56
# RPC地址
RpcUrl: "https://1rpc.io/bnb"
# 原生代币配置
NativeCurrency:
Symbol: BNB
Decimals: 18
# 稳定币合约地址
StablecoinCA: "0x55d398326f99059fF775485246999027B3197955"
# 交易滑点Bps
SlippageBps: 250
# DEX聚合器(relay)
DexAggregator: relay
# 数据API(gmgn/okx)
Datapi: okx
# Okx配置
OkxWeb3:
Apikey:
Secretkey:
Passphrase:
# 代理服务器配置
Sock5Proxy:
Host: 127.0.0.1 # 代理服务器地址
Port: 10808 # 代理服务器端口
Enable: false # 是否启用代理
# 电报机器人配置
TelegramBot:
Debug: true
ApiToken: 7916072799:AAFb-C25RgEAxNClxqeRpTkmO6C8e7FhzLs
WhiteList: # 白名单列表,填写Telegram UserId(非白名单用户不允许使用机器人,如果白名单为空则所有人都可以使用)
- 993021715
# 默认网格设置
DefaultGridSettings:
OrderSize: 30 # 每格大小
MaxGridLimit: 10 # 最大网格数量
StopLossExit: 0 # 止损金额阈值
TakeProfitExit: 80 # 盈利目标金额
TakeProfitRatio: 6 # 止盈百分比(%)
EnableAutoExit: false # 跌破自动清仓
LastKlineVolume: 1000 # 最近交易量
FiveKlineVolume: 0 # 最近5分钟交易量
GlobalTakeProfitRatio: 0 # 全局止盈涨幅(%)
DropOn: false # 防瀑布开关
CandlesToCheck: 3 # 防瀑布K线根数
DropThreshold: 20 # 防瀑布跌幅阈值百分比(%)
# 快速启动网格设置
QuickStartSettings:
OrderSize: 30 # 每格大小
MaxGridLimit: 10 # 最大网格数量
StopLossExit: 0 # 止损金额阈值
TakeProfitExit: 80 # 盈利目标金额
TakeProfitRatio: 6 # 止盈百分比(%)
EnableAutoExit: false # 跌破自动清仓
LastKlineVolume: 1000 # 最近交易量
FiveKlineVolume: 0 # 最近5分钟交易量
UpperPriceBound: 0.0002 # 网格价格上限
LowerPriceBound: 0.00005 # 网格价格下限
GlobalTakeProfitRatio: 0 # 全局止盈涨幅(%)
DropOn: false # 防瀑布开关
CandlesToCheck: 3 # 防瀑布K线根数
DropThreshold: 20 # 防瀑布跌幅阈值百分比(%)
# 创建代币策略的必要条件
TokenRequirements:
MinMarketCap: 200000 # 最小代币市值
MinHolderCount: 1500 # 最小代币持有人数
MinTokenAgeMinutes: 240 # 最小代币年龄(分钟)
MaxTokenAgeMinutes: 960 # 最高代币年龄(分钟)
除了 API 密钥需要使用自己的配置外,其他配置项可使用默认值。默认使用 USDT 进行交易,如需使用其他稳定币可修改 Chain.StablecoinCA 配置。
获取必要的 API 密钥
1. BSC RPC URL
- 访问 QuickNode
- 注册免费账户
- 创建 BSC 主网节点
- 获取 RPC URL
- 将 RPC URL 填写到配置文件
Chain.RpcUrl 项
2. OKX Web3 API
- 访问 OKX Web3 开发者平台
- 使用钱包登录并且在账号设置界面绑定邮箱和手机
- 前往 API Key 页面创建一个新的 API Key
- 将 API Key、Secret Key 和 Passphrase 填写到配置文件
OkxWeb3 项
3. Telegram Bot Token
- 在 Telegram 中找到 @BotFather
- 发送 /newbot 创建新机器人
- 按提示设置机器人名称和用户名
- 获取 Bot Token
- 将 Bot Token 填写到配置文件
TelegramBot.ApiToken 项
网络代理配置
由于网络限制可能导致无法访问 Telegram Bot 服务器,用户可以配置 Sock5Proxy 代理来解决连接问题:
Sock5Proxy:
Host: 127.0.0.1
Port: 10808
Enable: true # 设置为 true 启用代理
⚠️ 重要注意事项
安全风险
- 🔐 私钥安全:请确保私钥安全,建议使用专门的交易钱包
- 💾 数据备份:运行机器人后会自动创建
data 文件夹存储机器人数据,删除此文件夹将丢失所有数据,包括私钥,请谨慎操作
交易风险
- 💸 网络费用:每次交易都会产生 BSC 网络手续费
- 📈 市场风险:网格交易适合震荡行情,单边行情可能产生损失
- ⏰ 交易延迟:由于使用免费 API 服务,交易可能存在延迟,不适用于高波动代币交易
技术限制
- 🔄 API 限制:注意各 API 服务的调用频率限制
- 🛡️ 反爬虫机制:价格数据从 GMGN 和 OKX 抓取,如因反爬虫机制导致价格获取失败,可尝试修改配置文件
Datapi 选项
🤝 支持与反馈
📄 免责声明
本项目仅供学习和研究使用,使用者需自行承担交易风险。请谨慎使用,作者不对任何损失负责。
在使用本软件进行交易前,请确保您:
- 充分理解网格交易的风险和机制
- 具备相应的技术知识和风险承受能力
- 仅使用您可以承受损失的资金进行交易