撮合引擎通知跟单系统成交事件

在现代交易所或跟单交易系统(Copy Trading)中,成交消息从撮合引擎传播到跟单系统通常不会直接依赖单一方式,而是采用分层架构:

text 复制代码
撮合引擎
    ↓
成交回报模块(Trade Gateway)
    ↓
消息总线 / MQ(Kafka、Pulsar、RocketMQ等)
    ↓
跟单服务(Copy Trade Service)
    ↓
生成跟单订单
    ↓
订单网关
    ↓
TCP连接
    ↓
撮合引擎

撮合引擎内部一般使用 TCP

撮合引擎本身属于超低延迟系统:

  • Order Gateway → Matching Engine
  • Matching Engine → Trade Gateway

通常采用:

  • TCP
  • FIX协议
  • 私有二进制协议
  • Aeron
  • Chronicle Queue
  • 共享内存(同机房)

这里追求的是:

  • 微秒级延迟
  • 顺序保证
  • 不丢消息

例如:

text 复制代码
带单员下单
    ↓
Order Gateway
    ↓ TCP
Matching Engine
    ↓
成交

成交后通知跟单系统一般通过消息中间件

成交产生后:

json 复制代码
{
  "tradeId": 123456,
  "userId": 10001,
  "symbol": "BTCUSDT",
  "side": "BUY",
  "qty": 1,
  "price": 65000
}

这条消息会被发送到:

  • Kafka
  • Pulsar
  • RocketMQ
  • Redis Stream

某个 Topic:

text 复制代码
trade.executed

跟单服务订阅:

text 复制代码
trade.executed

收到后判断:

text 复制代码
userId=10001

是否带单员?
    是
        ↓
查找所有跟单用户
        ↓
生成跟单订单

为什么不用撮合引擎直接 TCP 推给跟单服务?

如果直接:

text 复制代码
撮合引擎
    ↓ TCP
跟单服务

会有几个问题:

耦合过高

跟单服务挂了:

text 复制代码
撮合引擎怎么办?

不能因为跟单系统故障影响核心交易。

扩展困难

未来可能还有:

  • 风控系统
  • K线系统
  • 清算系统
  • 资产系统
  • 推送系统

都需要成交数据。

如果全部 TCP:

text 复制代码
撮合引擎
 ├─ TCP -> 风控
 ├─ TCP -> 跟单
 ├─ TCP -> K线
 ├─ TCP -> 清算

连接数量爆炸。

重放困难

跟单服务重启后:

text 复制代码
刚才成交记录丢了

MQ 可以:

text 复制代码
offset 回退

重新消费。

TCP 做不到天然重放。

头部交易所(币安、OKX、Bybit 等)一般是:

text 复制代码
Matching Engine
    ↓
Internal Event Bus
    ↓
Copy Trading Service

这里甚至不一定是 Kafka。

可能是:

  • Aeron
  • Chronicle Queue
  • Disruptor RingBuffer
  • 自研 EventBus

因为 Kafka 延迟通常:

text 复制代码
1~10ms

而跟单交易希望:

text 复制代码
< 1ms

所以很多交易所采用:

text 复制代码
撮合引擎
    ↓
内部高速事件总线
    ↓
跟单服务

然后再异步写 Kafka:

text 复制代码
事件总线
 ├─ 跟单
 ├─ 风控
 └─ Kafka

用户客户端收到成交通知又是什么方式?

跟单员或普通用户看到:

text 复制代码
订单已成交

通常不是 MQ,而是:

text 复制代码
成交事件
    ↓
Push Service
    ↓
WebSocket
    ↓
APP/Web

即:

text 复制代码
撮合引擎
    ↓
MQ/EventBus
    ↓
Push Service
    ↓
WebSocket
    ↓
用户

现代交易所的主流设计是:

场景 通信方式
下单 → 撮合引擎 TCP / FIX / 私有二进制协议
撮合引擎 → 成交回报 内部 TCP / 共享内存 / EventBus
成交事件 → 跟单系统 MQ(Kafka/Pulsar/RocketMQ)或高速 EventBus
跟单系统 → 再次下单 TCP
成交通知用户 WebSocket

因此,对于"带单员成交后如何通知对应跟单员"的问题,在生产级系统中最常见的答案是:

成交事件先进入消息总线(Kafka、Pulsar、自研 EventBus 等),跟单服务订阅成交事件,再生成跟单订单;而不是撮合引擎直接通过 TCP 一对一通知跟单服务。

相关推荐
jrjrgood3 小时前
现货黄金和黄金期货的区别有哪些?如何投资?
大数据·人工智能·区块链
ellenwan20266 小时前
期货跨期价差程序化怎么做:天勤 SP 合约与腿比例核对
python·区块链
CTA终结者7 小时前
期货量化合约代码写错:天勤 symbol 格式与 silent 订阅坑
python·区块链
LadenKiller10 小时前
期货多品种轮动标的池:天勤 query_quotes 筛品种写法
python·区块链
lizhihai_9910 小时前
股市学习心得-六月的股市怎么应对
大数据·人工智能·科技·学习·区块链
nanawinona10 小时前
只会用 K 线算期货信号下一步怎么接到交易
python·区块链
2601_9602058811 小时前
2026年6月,中国品牌咨询行业正经历一场深刻的范式转移
大数据·人工智能·区块链
CTA终结者1 天前
期货量化主力换月程序怎么移仓:天勤 underlying_symbol 与任务切换
python·区块链
CTA量化套保1 天前
期货量化临期合约还能不能做:程序化到期禁开与强平写法
python·区块链