[AI tradingOS] AI自动交易器 | 绩效追踪与日志

第6章:AI自动交易器

欢迎回到nofx

通过前几章的积累,我们已经逐步构建了一个强大的系统:第1章:数据库与配置赋予其记忆能力,第2章:市场数据系统提供"市场耳目",第3章:多交易所交易接口配备"交易执行手",而第4章:AI决策引擎则构建了智能决策"大脑"。最后第5章:认证与用户管理通过身份验证机制保障系统安全。

现在想象你拥有一位天才厨师(AI决策引擎)、储备丰富的食材(市场数据)、精良的厨具(多交易所接口)和完美的食谱(提示词)。

如何确保这位厨师能持续烹饪、适应新食材并产出美味(盈利)佳肴,同时保持详细记录?

这就是AI自动交易器的用武之地

它是每个AI交易机器人的"专属管家"

AI的"私人管家":维持系统运转

AI自动交易器视为特定交易策略的全职助理。它不只执行单次交易,而是管理交易机器人的全生命周期

核心职责包括:

  • 定时唤醒:按设定间隔检查市场
  • 信息收集:获取最新市场数据和账户状态
  • 专家咨询:向AI决策引擎寻求建议
  • 计划执行:通过多交易所接口下单交易
  • 记录存档:记录每个动作、决策和绩效
  • 持续进化:利用历史结果优化策略(主要通过改进AI提示词实现)

这个组件将前几章的所有概念整合为持续运行的智能交易机器人。

场景:"运行我的比特币策略"

假设要在币安上运行基于DeepSeek模型的BTCUSDT交易机器人,每3分钟扫描市场:

若无自动交易器,你需要:

  1. 手动获取BTCUSDT数据
  2. 手动构建包含策略和账户信息的提示词
  3. 手动发送给DeepSeek模型
  4. 手动解析复杂响应
  5. 手动决定是否执行
  6. 手动向币安发送订单
  7. 手动记录所有操作
  8. 每3分钟重复上述流程!

人力根本无法完成!而AI自动交易器能自动化整个流程,启动后即可7×24小时持续运行。

核心机制

1. 唯一标识与配置

每个自动交易器都有唯一ID名称,以及特定配置参数:

配置项 说明 示例
ID/Name 唯一标识和显示名称 btc-deepseek-binance
AIModel 使用的AI模型 deepseek
Exchange 交易平台 binance
API Keys 交易所和AI模型的密钥 sk-xyz...
ScanInterval 市场扫描间隔 3分钟
InitialBalance 初始资金(用于绩效追踪) 1000 USDT
SystemPromptTemplate 使用的交易策略模板文件 default

这些配置在创建时从数据库加载(参考第1章)。

2. 持续交易循环

自动交易器的核心是循环执行以下步骤:

  1. 暂停检查:是否因风控暂停
  2. 日绩效重置:新交易日重置盈亏统计
  3. 构建上下文
    • 从交易接口获取账户余额和持仓
    • 从市场系统获取最新行情数据
    • 加载该机器人历史表现
  4. 获取AI决策
    • 发送上下文给AI决策引擎
    • 接收包含思维链和交易指令的响应
  5. 指令排序:确保平仓优先于开仓
  6. 执行交易
    • 安全检查(如避免重复开仓)
    • 通过交易接口下单
    • 设置止损止盈
  7. 记录日志 :保存完整操作记录到decision_logs/

3. 绩效追踪与日志

自动交易器维护关键指标如initialBalancedailyPnL,并通过DecisionLogger记录每个循环的详细信息,包括:

  • 账户快照(权益、可用余额)
  • 当前持仓
  • AI使用的完整提示词
  • AI的思维链推理过程
  • 最终交易决策JSON
  • 每项操作的执行结果

这些日志对透明度、调试和长期优化至关重要。

⭕使用方式

开发者通过配置创建AutoTrader实例后,调用Run()即可启动:

go 复制代码
func startBot() {
    // 1. 创建配置
    config := trader.AutoTraderConfig{
        ID: "btc-strategy-1",
        AIModel: "deepseek",
        Exchange: "binance",
        ScanInterval: 3 * time.Minute,
        SystemPromptTemplate: "default"
    }

    // 2. 创建实例
    myBot, _ := trader.NewAutoTrader(config)
    
    // 3. 启动循环
    go myBot.Run()
    
    // 运行30分钟后停止
    time.Sleep(30 * time.Minute)
    myBot.Stop()
}

底层实现

核心工作流

关键代码

  1. 结构体定义(trader/auto_trader.go)
go 复制代码
type AutoTrader struct {
    id       string
    config   AutoTraderConfig
    trader   Trader          // 交易接口
    mcpClient *mcp.Client    // AI通信客户端
    logger   *DecisionLogger // 日志记录器
}
  1. 主循环逻辑
go 复制代码
func (at *AutoTrader) runCycle() error {
    // 1. 构建交易上下文
    ctx := at.buildTradingContext()
    
    // 2. 获取AI决策
    decision := decision.GetFullDecision(ctx, at.mcpClient)
    
    // 3. 执行排序后的指令
    for _, action := range sortActions(decision.Actions) {
        at.executeAction(action)
    }
    
    // 4. 保存完整记录
    at.logger.Log(decision)
    return nil
}
  1. 指令执行示例(做多)
go 复制代码
func (at *AutoTrader) executeOpenLong(d Decision) error {
    // 避免重复开仓
    if at.hasPosition(d.Symbol, "long") {
        return errors.New("existing position")
    }
    
    // 计算数量并下单
    price := market.Get(d.Symbol).CurrentPrice
    qty := d.PositionSizeUSD / price
    result, _ := at.trader.OpenLong(d.Symbol, qty, d.Leverage)
    
    // 设置止损止盈
    at.trader.SetStopLoss(d.Symbol, qty, d.StopLoss)
    return nil
}

小结

AI自动交易器 作为nofx的运营中枢,通过持续循环整合市场数据采集、AI决策咨询、交易执行和全流程记录,将前几章的独立模块转化为有机整体

这种设计使得单个交易机器人能够安全、透明地自动化运行。

理解单个自动交易器的工作原理后,下一步自然需要管理多个机器人。在第7章:交易管理器中,我们将探索如何统一管控这些强大的自动交易器。

相关推荐
AAA阿giao3 小时前
用 AI 工程师 Trae Solo ,一个人打造“绘本岛”:从想法到上线只需三步
人工智能·全栈·trae
Blossom.1183 小时前
大模型量化压缩实战:从FP16到INT4的生产级精度保持之路
开发语言·人工智能·python·深度学习·神经网络·目标检测·机器学习
K2_BPM3 小时前
打通 AI 与业务的 “最后一公里”:流程优化的底层逻辑与三种战略选择
人工智能·机器学习
Ro Jace3 小时前
三国华容道(横刀立马)移动策略
android·java·数据库·人工智能·深度学习·神经网络·游戏
taxunjishu3 小时前
Modbus TCP 转 Modbus RTU物联网网关实现光伏产线西门子与罗克韦尔PLC互联
人工智能·物联网·工业物联网·工业自动化·总线协议
User_芊芊君子3 小时前
从“能说会道”到“自主思考”:一文读懂AI的过去、现在与未来
人工智能·chatgpt
半臻(火白)3 小时前
Meta DreamGym:用合成经验,重构智能体训练的“低成本革命”
人工智能
快乐非自愿3 小时前
数智化时代:AI技术重构企业财务管理系统的底层逻辑与实践
大数据·人工智能·低代码
草莓熊Lotso4 小时前
Git 本地操作入门:版本控制基础、跨平台部署与仓库核心流程
开发语言·人工智能·经验分享·git·后端·架构·gitee