match-trade超高效的交易所撮合引擎

简介: match-trade超高效的交易所撮合引擎

介绍

match-trade超高效的交易所撮合引擎,采用伦敦外汇交易所LMAX开源的Disruptor框架,用Hazelcast进行分布式内存存取,以及原子性操作。使用数据流的方式进行计算撮合序列,才用价格水平独立撮合逻辑,实现高效大数据撮合。

优势

  • match-engine水平价格为独立撮合逻辑,相比于订单队列为撮合队列的交易引擎来说,价格区间越小时,性能越优越。
  • match-engine不再对撮合薄进行排序,而是用并行流计算出最优撮合价格,进行撮合。
  • match-engine每个价格下的订单都是异步完成被撮合。独立价格下订单不影响下一个新发生的撮合。
  • match-engine每个价格撮合都是独立的,与下一个价格没的关系,实现快速吃单。
  • match-engine每个新的订单经历撮合处理器后,后续逻辑采用并行计算,能更快速反馈数据撮合结果。
  • match-engine使用数据流反应式MQ消费,降低由MQ带来的数据延迟。
  • match-engine撤单走独立的逻辑,不用和下单在一个处理序列。

技术选择

  • Disruptor: 号称每秒钟承载600万订单级别的无锁并行计算框架,主要选择原因还是并行计算。
  • Hazelcast: 很好进行内存处理,很强原子性保障的操作能力。同时分布式内存实现很简单,能自动内存集群。据说火币也在用。
  • rocketmq: 消息可以做到0丢失,支持10亿级别的消息堆积,不会因堆积导致性能下降,主要是经过双11检验
  • WebFlux: 它能够充分利用多核 CPU 的硬件资源去处理大量的并发请求。

描述

用户输入包括:

  • 创建新的委托单(NewOrder):一个新的委托单可以作为交易撮合引擎的输入,引擎会尝试将其与已有的 委托单进行撮合。
  • 取消已有的委托单(CancelOrder):用户也可以取消一个之前输入的委托单,如果它还没有执行的话,即开口订单。

委托单:

  • 限价委托单
    限价委托单是在当前的加密货币交易环境中最常用的委托类型。这种委托单允许用户指定一个价格,只有当撮合引擎找到同样价格甚至更好价格的对手单时才执行交易。
  • 市价委托单
    市价委托单的撮合会完全忽略价格因素,而致力于有限完成指定数量的成交。市价委托单在交易委托账本中有较高的优先级,在流动性充足的市场中市价单可以保证成交。不充足时,撮合完最后一条撤销。
  • 止损委托单
    止损委托单尽在市场价格到达指定价位时才被激活,因此它的执行方式与市价委托单相反。一旦止损委托单激活,它们可以自动转化为市价委托单或限价委托单。(未实现)

撮合流程

限价撮合:

限价撮合.png

市价撮合:

市价撮合.png

目前就实现这两种订单撮合

代码执行流程图(感谢读者提供的图)

match-trade最高效的交易所撮合引擎

订单簿为撮合簿时代码解析

这个是一个简单流盘口计算demo

//获取匹配的订单薄数据IMap<Long, Order> outMap = hzInstance.getMap(HzltUtil.getMatchKey(coinTeam, isBuy));/** * - * -使用Java 8 Stream API中的并行流来计算最优 * -能快速的拿到撮合对象,不用排序取值,降低性能消耗 */Order outOrder = outMap.values().parallelStream().min(HzltUtil::compareOrder).get();//这种方式最难的,就是整理盘口深度数据了    /**     * -     * -获取行情深度     *      * @param coinTeam 交易队     * @param isBuy    是否是买     * @return List<Depth>     */    public List<Depth> getMarketDepth(String coinTeam, Boolean isBuy) {        List<Depth> depths = new ArrayList<Depth>();        IMap<Long, Order> map = hzInstance.getMap(HzltUtil.getMatchKey(coinTeam, isBuy));        if (map.size() > 0) {            /**             * -这个流:主要是安价格分组和统计,使用并行流快速归集。             */             List<Depth> list = map.entrySet().parallelStream().map(mo -> mo.getValue())                    .collect(Collectors.groupingBy(Order::getPrice)).entrySet().parallelStream()                    .map(ml -> new Depth(ml.getKey().toString(),                            ml.getValue().stream().map(o -> o.getUnFinishNumber()).reduce(BigDecimal.ZERO, BigDecimal::add)                                    .toString(),                            "0", 1, coinTeam, isBuy))                    .sorted((d1, d2) -> HzltUtil.compareTo(d1, d2)).collect(Collectors.toList());            /**             * -这个流:主要是盘口的累计计算,因涉及排序选择串行流             */            list.stream().reduce(new Depth("0", "0", "0", 1, coinTeam, isBuy), (one, two) -> {                one.setTotal((new BigDecimal(one.getTotal()).add(new BigDecimal(two.getNumber()))).toString());                depths.add(new Depth(two.getPrice(), two.getNumber(), one.getTotal(), two.getPlatform(),                        two.getCoinTeam(), two.getIsBuy()));                return one;            });        } else {            Depth depth = new Depth("0", "0", "0", 1, coinTeam, isBuy);            depths.add(depth);        }        return depths;    }

测试结果

在我8cpu,16G内存的开发win10系统上测试结果:

  • Disruptor单生产者初始化10万不能撮合的订单耗时:约700毫秒
  • Disruptor多生产者初始化10万不能撮合的订单耗时:约20秒
  • 实际单吃完1-100价格内随机数量的10万订单耗时:约400毫秒
相关文章
|
消息中间件 设计模式 移动开发
高德打车通用可编排订单状态机引擎设计
订单状态流转是交易系统的最为核心的工作,订单系统往往都会存在状态多、链路长、逻辑复杂的特点,还存在多场景、多类型、多业务维度等业务特性。在保证订单状态流转稳定性的前提下、可扩展性和可维护性是我们需要重点关注和解决的问题。
高德打车通用可编排订单状态机引擎设计
|
3月前
|
前端开发 JavaScript NoSQL
订单排队融合DAPP:去中心化智能合约线上商城模式
本文介绍了城市酷选模式和DApp开发的示例代码,涵盖前端(React)、后端(Node.js + Express)和区块链(Solidity + Web3.js)多个方面。通过示例代码展示了如何实现用户、订单和商家管理,以及智能合约的创建和交互。请注意,这些代码仅为示例,实际项目中需进行详细开发和测试,确保安全性、性能和用户体验。
|
5月前
|
弹性计算 监控 Serverless
函数计算产品使用问题之如何处理银行转账场景遇到的高并发问题
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
安全 区块链 开发者
DAPP去中心化博饼交易LP兑换系统开发模式案例
完成智能合约的开发后,我们需要将其部署到区块链网络中
|
算法 区块链
去中心化交易系统开发|LP模式案例
基于区块链的基本特性,区块链通常是由若干个区块构成
|
Kubernetes 容器
撮合交易系统简介
为了应对更高峰值的成交量,国内各金融机构,主要是交易所和银联、中心之间需求越来越多
452 0
撮合交易系统简介
Go语言银联8583报文解析库,支持联小额免密付和银商聚合支付
Go语言银联8583报文解析库,支持联小额免密付和银商聚合支付
|
算法 测试技术 Linux
国王小组:搭建交易所开源的订单匹配引擎
开源的订单匹配引擎 国王小组提供了构成订单匹配引擎的底层组件。 订单匹配是接受证券(或其他可替换资产)的买单和卖单的过程,并对其进行匹配,以允许原本互不相识的各方之间进行交易。 订单匹配引擎是每个金融交易所的核心,并可用于许多其他情况,包括交易非金融资产,作为交易算法的测试平台,等等。
国王小组:搭建交易所开源的订单匹配引擎
alipay.trade.refund(统一收单交易退款接口) 集成流程
接口名称:统一收单交易退款接口 英文名称:alipay.trade.refund 主要用于交易资金的退款 一、文档地址 官方文档地址:[url]https://docs.open.alipay.com/api_1/alipay.trade.refund[/url] 二、开发前准备工作 调用步骤:[url]https://openclub.alipay.com/read.php?tid=12194&fid=69[/url] 注意事项:1、支持沙箱测试;2、需签约并添加功能;3、支持第三方调用。
2395 0