收藏

Spring Cloud+Vertx+Disruptor 撮合交易系统实战

全网少有剖析证券行业核心系统的课程,带你吃透金融市场资金股票流转的核心设施

SpringCloud+Vertx+Disruptor 撮合交易系统实战

¥388.00
已完结 难度 初级 时长 26小时30分钟 学习人数 453 综合评分 10.00

课程对比栏

隐藏
  • 1
    可继续添加课程
  • 2
    可继续添加课程
  • 3
    可继续添加课程
  • 4
    可继续添加课程
对比
清空对比栏
  • 第1章 初识证券交易系统 6 节 | 58分钟

    本章主要介绍为何要带大家从零开始开发一套高可用的撮合交易实战课程,之后会聊聊这个行业的参与者们,介绍金融行业的系统有哪些部分组成,它们的架构是什么样子的。希望大家都能通过这门课程,学有所成,学有所归。

    收起列表

    • 图文: 1-1 课前必读(不看会错过一个亿)
    • 视频: 1-2 课程介绍及学习指导 (15:22) 试看
    • 视频: 1-3 证券金融行业 (12:43) 试看
    • 视频: 1-4 行业系统全景图 (06:28)
    • 视频: 1-5 深入了解接入层-中台服务-交易系统-1 (09:02)
    • 视频: 1-6 深入了解接入层-中台服务-交易系统-2 (14:12)
  • 第2章 Vue委托终端开发准备 3 节 | 35分钟

    本章将带大家对委托终端的开发做足准备,包括框架选型(通过对不同时期的前端框架进行优劣比较,着重讲解Vue作为前端主框架的优势和Vue应用的思路和通过实例快速入门Electron两方面的内容。

    收起列表

    • 视频: 2-1 Vue高性能的秘密 (12:34)
    • 视频: 2-2 Vue-Cli搭建委托终端脚手架 (11:31)
    • 视频: 2-3 Web跨界神器electron (10:17)
  • 第3章 订单出发-结合Element UI开发委托终端 试看 13 节 | 186分钟

    本章将会带大家开发一个委托终端,委托终端主要使用Element UI作为组件库, 除了使用Element UI还会根据柜台的业务开发自定义的的组件。在开发的过程中着重展示一个结构清晰的代码结构应该怎么组织各个层级方法的调用关系。...

    收起列表

    • 视频: 3-1 el-input入门--开发简洁登录页面 (17:06) 试看
    • 视频: 3-2 el-dropdown下拉菜单应用--创建主页面顶部导航 (15:59)
    • 视频: 3-3 跨组件通信--创建主页面侧边导航栏 (17:49)
    • 视频: 3-4 前端路由控制--密码设置页面开发【选学】 (14:47)
    • 视频: 3-5 el-select的使用--银证转账页面开发【选学】 (12:39)
    • 视频: 3-6 绕不开的表格和分页控件--资金持仓页面开发-1 (13:16)
    • 视频: 3-7 绕不开的表格和分页控件--资金持仓页面开发-2 (11:16)
    • 视频: 3-8 el-table回顾--实时委托和成交页面开发 (18:45)
    • 视频: 3-9 el-autocomplete的使用--历史委托成交查询页面开发-1 (12:18)
    • 视频: 3-10 el-autocomplete的使用--历史委托成交查询页面开发-2 (15:19)
    • 视频: 3-11 el-autocomplete回顾-委托组件开发 (22:50)
    • 视频: 3-12 自定义OrderBook订单簿组件和总结 (13:38)
    • 作业: 3-13 思考委托终端是否有其他的技术方案
  • 第4章 Spring Cloud柜台开发准备 4 节 | 40分钟

    本章将带大家对柜台开发做足知识准备,包括了解柜台在交易撮合系统中会扮演一个什么样的角色,柜台的技术选型,如何使用SpringCloud搭建柜台开发的脚手架三方面的内容。

    收起列表

    • 视频: 4-1 柜台业务 (04:07)
    • 视频: 4-2 柜台开发技术选型 (05:00)
    • 视频: 4-3 柜台脚手架搭建-1 (16:38)
    • 视频: 4-4 柜台脚手架搭建-2 (13:47)
  • 第5章 订单第一站-柜台 22 节 | 293分钟

    本章将带大家开发基于Spring Cloud的柜台,包括Token身份认证接口(使用Redis存储Token进行认证),查询类接口(使用数据库+缓存的方式提高系统负载能力),委托发送接口,自动提示框接口(使用倒排索引的方式提高检索效率)。...

    收起列表

    • 视频: 5-1 登录接口-前端基础代码完善 (21:40)
    • 视频: 5-2 登录接口-用Redis存储验证码 (20:06)
    • 视频: 5-3 登录接口-验证码-1 (12:27)
    • 视频: 5-4 登录接口-验证码-2 (13:39)
    • 视频: 5-5 登录接口-验证码-3 (12:40)
    • 视频: 5-6 登录接口-验证码-4 (10:08)
    • 视频: 5-7 登录接口-身份校验-1 (14:03)
    • 视频: 5-8 登录接口-身份校验-2 (12:35)
    • 视频: 5-9 登录接口-身份校验-3 (16:25)
    • 视频: 5-10 退出登录接口 (10:32)
    • 视频: 5-11 密码修改接口 (17:11)
    • 视频: 5-12 银证转账的秘密 (04:18)
    • 视频: 5-13 委托成交持仓接口-1 (13:37)
    • 视频: 5-14 委托成交持仓接口-2 (14:24)
    • 视频: 5-15 委托成交持仓接口-3 (13:18)
    • 视频: 5-16 委托成交持仓接口-4 (17:10)
    • 视频: 5-17 委托发送-自动提示框接口-1 (13:44)
    • 视频: 5-18 委托发送-自动提示框接口-2 (16:24)
    • 视频: 5-19 保存委托和总结-1 (16:09)
    • 视频: 5-20 保存委托和总结-2 (12:26)
    • 视频: 5-21 保存委托和总结-3 (09:55)
    • 作业: 5-22 柜台开发如何做好高可用(双活或多活)
  • 第6章 Vertx网关开发准备 3 节 | 39分钟

    本章将带大家对网关的开发做足知识准备,包括了解网关在交易撮合系统中发挥的作用,在柜台和交易之间的隔离,协议转换的作用,了解TCP网络编程的重要技术点报文的编解码和重连的设置。

    收起列表

    • 视频: 6-1 网关业务和实现框架 (10:15)
    • 视频: 6-2 TCP服务端--编解码 (10:30)
    • 视频: 6-3 TCP客户端--断线重连 (17:54)
  • 第7章 订单第二站-网关 11 节 | 140分钟

    本章将带大家完成网关的开发,柜台使用Vertx的TCP模块作为开发框架,使用Vertx开发TCP的服务端和客户端,并会重点带大家分析TCP网络编程中如何使用自定义的缓存队列防止系统的阻塞。

    收起列表

    • 视频: 7-1 网关(服务端)--数据编解码 (20:34)
    • 视频: 7-2 网关(服务端)--连接处理器-1 (17:36)
    • 视频: 7-3 网关(服务端)--连接处理器-2 (21:17)
    • 视频: 7-4 柜台(客户端)--生成报文-1 (15:46)
    • 视频: 7-5 柜台(客户端)--生成报文-2 (12:31)
    • 视频: 7-6 柜台(客户端)--生成报文-3 (12:19)
    • 视频: 7-7 柜台(客户端)--生成报文-4 (06:49)
    • 视频: 7-8 柜台(客户端)--发送报文-1 (15:07)
    • 视频: 7-9 柜台(客户端)--发送报文-2 (09:20)
    • 视频: 7-10 代码联调和小结 (08:13)
    • 作业: 7-11 如何更好的构建统一数据通信协议,降低开发成本
  • 第8章 Raft排队机开发准备 4 节 | 49分钟

    本章将带大家对排队机的开发做足知识准备,包括了解排队机在交易撮合系统中发挥的作用(主要用于订单的收集,定序和广播),了解排队机如何保证强一致性和高可用,并基于现有的SOFAJRaft框架完成一个高可用和强一致性的key-value数据库用来保存申报数据。 ...

    收起列表

    • 视频: 8-1 排队机业务分析 (05:23)
    • 视频: 8-2 高可用和一致性 (19:57)
    • 视频: 8-3 raft based key-value db-1 (10:21)
    • 视频: 8-4 raft based key-value db-2 (13:16)
  • 第9章 订单第三站-排队机 7 节 | 67分钟

    本章将带大家开发一个基于SOFAJRaft 和Vertx的UDP模块作为开发框架的排队机,完成从网关收集订单,定序,存储等功能。为了保证业务上的公平性,排队机以固定的频率从网关收集订单,对所有申报进行定序,最后存放到具有强一致性和高可用特性的Key-Value数据库中。...

    收起列表

    • 视频: 9-1 Key Value Store DB 初始化-1 (12:11)
    • 视频: 9-2 Key Value Store DB 初始化-2 (11:17)
    • 视频: 9-3 收集网关订单(排队机Consumer)-1 (10:30)
    • 视频: 9-4 收集网关订单(排队机Consumer)-2 (10:03)
    • 视频: 9-5 收集网关订单(网关Provider) (07:41)
    • 视频: 9-6 定序和小结 (15:12)
    • 作业: 9-7 对排队机的特殊场景定制数据一致性算法
  • 第10章 Disruptor撮合核心开发准备 4 节 | 39分钟

    本章将带大家对撮合核心开发做足知识准备,包括了解撮合核心的业务知识以及它在撮合交易系统中发挥的作用,TCP/UDP在撮合核心开发当中的优劣选择,Disruptor的入门和使用三方面的内容。

    收起列表

    • 视频: 10-1 撮合核心业务 (06:08)
    • 视频: 10-2 追求极致的Disruptor (10:11)
    • 视频: 10-3 Disruptor的使用入门-1 (10:32)
    • 视频: 10-4 Disruptor的使用入门-2 (11:47)
  • 第11章 订单终点站-撮合核心 16 节 | 191分钟

    本章将带大家开发一个撮合核心,撮合核心主要使用Disruptor,eclipse collections作为开发框架,完成使用NACK策略接收排队机的组播数据,使用自定义的订单簿数据结构对委托进行撮合和存储,对申报的结果进行广播等功能,本章的难点在于如何规避UDP丢包和乱序的问题,如何设计一个较为高效的订单簿数据结构。...

    收起列表

    • 视频: 11-1 UDP NACK 广播与接收-1 (15:17)
    • 视频: 11-2 UDP NACK 广播与接收-2 (14:16)
    • 视频: 11-3 UDP NACK 广播与接收-3 (10:52)
    • 视频: 11-4 UDP NACK 广播与接收-4 (14:32)
    • 视频: 11-5 UDP NACK 广播与接收-5 (09:42)
    • 视频: 11-6 前置风控处理器-1 (11:35)
    • 视频: 11-7 前置风控处理器-2 (12:00)
    • 视频: 11-8 撮合处理器-OrderBucket-1 (12:14)
    • 视频: 11-9 撮合处理器-OrderBucket-2 (11:53)
    • 视频: 11-10 撮合处理器-OrderBook-1 (10:43)
    • 视频: 11-11 撮合处理器-OrderBook-2 (13:06)
    • 视频: 11-12 撮合处理器-OrderBook-3 (10:12)
    • 视频: 11-13 行情发布处理器-1 (13:44)
    • 视频: 11-14 行情发布处理器-2 (09:11)
    • 视频: 11-15 组装Handlers和小结 (21:35)
    • 作业: 11-16 更优秀的撮合算法
  • 第12章 行情发送、订阅和和课程总结 9 节 | 111分钟

    本章先带大家了解柜台如何通过总线接收撮合核心发布的行情和撮合数据,委托终端如何从柜台订阅委托和成交的变动信息,如何请求股票的订单簿数据,最后对整个课程业务、技术做全面总结。

    收起列表

    • 视频: 12-1 支线--maven打包 (10:20)
    • 视频: 12-2 总线数据处理器 (14:29)
    • 视频: 12-3 行情处理器 (06:17)
    • 视频: 12-4 撮合数据处理器-1 (10:33)
    • 视频: 12-5 撮合数据处理器-2 (13:00)
    • 视频: 12-6 服务端(柜台)的websocket推送 (13:43)
    • 视频: 12-7 客户端(委托终端)的websocket订阅-1 (16:06)
    • 视频: 12-8 客户端(委托终端)的websocket订阅-2 (17:06)
    • 视频: 12-9 课程全面总结 (09:02)
  • 第13章 客户端问题修复 2 节 | 18分钟

    在课程的学习中,不少小伙伴反馈在开发调试阶段,只要一改vue的前端代码,推送就会失效。本章节的主要内容,是在客户端的代码中,增加主动控制eventbus的连接行为的代码,实现断线重连,通过客户端主动连接和订阅来修复推送收不到的问题。...

    收起列表

    • 视频: 13-1 sessionStorage和localStorage的区别 (05:54)
    • 视频: 13-2 客户端自动重连eventbus (11:40)
  • 第14章 柜台高可用的深入讲解 9 节 | 91分钟

    柜台一个比较重要的特点是保证业务的连续性,因此高可用是柜台必不可少的特性,本章节,将深入探索如何借助zookeeper,实现柜台的高可用。除了高可用,我们还会针对旧版本撮合系统模块众多,依赖复杂的问题进行优化,通过架构的重新设计。精简模块,降低数据流转的复杂度,从而提升系统的健壮性。...

    收起列表

    • 视频: 14-1 柜台模块升级思路梳理 (06:00)
    • 视频: 14-2 基础版本升级 (07:12)
    • 视频: 14-3 zookeeper工具类 (13:13)
    • 视频: 14-4 订单路由-柜台初始化(上) (14:19)
    • 视频: 14-5 订单路由-柜台初始化(中) (17:10)
    • 视频: 14-6 订单路由-柜台初始化(下) (14:15)
    • 视频: 14-7 订单路由-发送委托 (09:49)
    • 视频: 14-8 订单路由-接收撮合模块数据 (06:11)
    • 视频: 14-9 客户端长Long数据精度丢失问题 (02:21)
  • 第15章 如何让撮合变得更快&更安全 11 节 | 205分钟

    撮合模块是整个交易系统的核心,为了更快的撮合速度,我们重新设计了撮合的架构,在新的撮合模块中,委托处理的链条进行了并行化升级,同时新增了主备模式和宕机恢复的机制来保证高可用,快跟随我们的课程来看看这些特性是如何实现的吧...

    收起列表

    • 视频: 15-1 撮合模块升级思路梳理 (06:28)
    • 视频: 15-2 OrderBook序列化和反序列化(上) (17:14)
    • 视频: 15-3 OrderBook序列化和反序列化(中) (17:25)
    • 视频: 15-4 OrderBook序列化和反序列化(下) (11:14)
    • 视频: 15-5 Write Ahead Logging (19:45)
    • 视频: 15-6 委托行情发布 (15:31)
    • 视频: 15-7 快照行情发布 (23:11)
    • 视频: 15-8 Leader Election (26:56)
    • 视频: 15-9 撮合模块初始化(上) (29:43)
    • 视频: 15-10 撮合模块初始化(下) (27:01)
    • 视频: 15-11 系统演示和总结 (10:15)
本课程已完结

试看

全部试看小节



讲师

Gudy 软件工程师

Gudy,金融行业的系统架构师。曾就职于东方财富网,上海某交易所、上海某上市大型券商,现就职于上海某公募基金,不同类型金融机构从业经验,负责风控以及交易系统方面的建设,一路走来,深感国内外金融行业IT系统建设方面的差距和不足,想把这些年的经验与技术通过慕课网分享给大家,期望能有更多志同道合的小伙伴加入到金融行业IT基础设施的建设中来。

课程预览

检测到您还没有关注慕课网服务号,无法接收课程更新通知。请扫描二维码即可绑定
重新观看
意见反馈 帮助中心 APP下载
官方微信

学习咨询

选课、学习遇到问题?

扫码添加指导老师 1V1 帮助你!

添加后老师会第一时间解决你的问题