vnpy乱乱谈 02架构

转自:http://101.132.65.227/?p=51

听到架构这个词先不要害怕. 其实这部分内容还是挺简单的. 一般而言, 一个交易系统我们可以简单的分成输入, (系统)处理, 输出三个部分.

常见的输入就是交易所出来的行情(还有回报)了, 行情有很多其他叫法quote, tick, market data 反正都是差不多的意思.

而输出呢, 无非就是下单, 或者撤单, 或者查询.

整个处理流程是, 系统接收到一个quote, 然后系统内的模型会评估这个quote, 看看是否后面要下单, 或者撤单. 比如收到一个quote价格很便宜, 模型算出来这个quote价格被严重低估, 那么系统就会发出买入指令.好这里引入了一个新的东西叫模型, 或者叫策略. 所以现在架构看起来是这样的, 我们的交易系统里面有一个东西叫模型

更进一步, 是不是还缺点东西? 试想一下如果你的model不小心写错了, 会疯狂的下单, 那么会导致怎么样的后果? 或者是本来要买100手的变成10000手, 不用想都知道后果基本都挺严重的对吧. 所以我们需要一个东西来审查一下我们下的单子是否是正常的, 一般而言这个东西叫做风控, 对应的还有一个东西叫做流控.

风控一般是做安全检查的, 比方说检查你的单子价格是否正确, 是不是负数啊, 数量是否正确, 是否等于0或者是过大啊之类的. 而流控呢则是控制单位时间内可以下多少单子, 很多地方风控流控不做严格区分的, 讲风控一般也包含流控. 所以现在我们的交易系统变成了下面这样

试想一下, 如果不同的交易所的行情和交易指令有不同的格式, 那么如果我们的交易系统要支持多个交易所, 是不是还缺点什么? 一般来讲我们都比较喜欢把不同但是类似的东西统一来处理. 对行情来讲一般我们不直接处理交易所过来的原始数据, 而是做一下转化, 转化为我们内部的一种数据结构来处理, 这样多家不同的交易所的行情最终都是转化为我们自己的数据结构处理的. 而对交易来说, 则是我们内部的下单指令转化到各个交易所特有的指令. 这个转化的部件可以叫adapter也可以叫gateway. 所以我们的结构演变成下面这样了.

麻雀虽小五脏俱全, 现在基本上重要的东西都有了, 复杂一点的系统其实也就多拓展了一些内如, 下面是来自于AlgoTrader官方的架构图.

看着挺唬人但其实没多出来太多东西.

我们再来看看vnpy的, 大概是这样

EventEngine是整个事件引擎, 相当于AlgoTrader里面的Esper complex Event Processing Engine, 但要简单很多. 负责事件的分发处理.

gateway对外适配了CTP, FEMAS等金融接口, 对内转化为一致的数据结构.

DrEngine是行情数据记录引擎, 相当于AlgoTrader的Database部分, 主要做的事情:

  1. 记录tick数据
  2. 由tick数据生产并记录bar数据

CtaEngine模块是CTA策略引擎, 相当于algotrader的strategy模块.

RmEngine是风控引擎.

看起和AlgoTrader基本没差太多对吧? 但是呢仔细看一下, 还是有一些区别的, 在vnpy里面:

  • 界面与逻辑耦合到一起
  • IO(数据落地的mango db)和逻辑耦合到一起

这两点异同其实是会照成比较大的性能问题的. 这个问题留在后续的篇幅中继续.

本篇完.

参考:

SYSTEM ARCHITECTURE

The architecture of AlgoTrader is composed of the following components which is shown as the 1st figure

The AlgoTrader Server provides the infrastructure for all strategies running on top of it. The AlgoTrader Server holds the main Esper Complex Event Processing (CEP) engine. It is responsible for all domain model objects and their persistence in the database. Different market data adapters are available to process live and historical market data. On the other end adapters for different execution brokers and exchanges are available, which are responsible for placing orders and receiving executions.

The AlgoTrader Server also provides business components for back testing, parameter optimization, analysis, execution management, risk management, reporting, reconciliation and hedging.

On top of the AlgoTrader Server any number of strategies can be deployed. Strategies can either be coded purely in Java or in a combination of Java and Esper code. Esper based strategies make use of a dedicated Esper CEP engine. A strategy can deploy any number of SQL-like Esper statements for time-based market data analysis and signals generation. Esper statements can invoke any number of procedural actions, such as placing an order or closing a position, which are coded in Java. The combination of Esper statements and Java Code provides a best-of-both-worlds approach.

For management and monitoring of the system different GUI clients exist. The AlgoTrader HTML5 Frontend provides trading related functionality like charting, orders, positions & market data. Eclipse or IntelliJ IDE’s are used for strategy development. The EsperHQ client manages the Esper CEP engine.

For productive installations and deployment AlgoTrader uses Docker.

https://github.com/vnpy/vnpy

[转]vnpy乱乱谈 02架构的更多相关文章

  1. 浅谈MySQL架构体系

    一  数据库和数据库实例 在MySQL的学习研究中,存在两个非常容易混淆的概念,即数据库和数据库实例.在MySQL中,数据库和数据库实例定义如下: 数据库:存储数据的集合: 数据库实例:操作数据库的集 ...

  2. 浅谈SDN架构下的运维工作

    导读 目前国内的网络运维还处于初级阶段,工作人员每天就像救火一样,天天疲于奔命.运维人员只能埋头查找系统运行的日志,耗时耗力,老眼昏花不说,有时候忙了半天还一无所获,作为运维工程师的你,有木有遇到过类 ...

  3. 以用户注册功能模块为例浅谈MVC架构下的JavaWeb开发流程

    JavaWeb应用开发,撇开分布式不谈,只讨论一个功能服务应用的开发,无论是使用原生的Servlet/JSP方案,还是时下的SSM架构,都有一套经过工程实践考验的最佳实践,这综合考虑了团队协作.项目管 ...

  4. SGU 乱乱开

    本解题报告 乱抄,乱写,随性随心,不喜多喷! SGU 142: 思路:一个string的字串不会超过2^20个,我们枚举出来就好了. 我出错点:数组RE #include<stdio.h> ...

  5. 解构C#游戏框架uFrame兼谈游戏架构设计

    1.概览 uFrame是提供给Unity3D开发者使用的一个框架插件,它本身模仿了MVVM这种架构模式(事实上并不包含Model部分,且多出了Controller部分).因为用于Unity3D,所以它 ...

  6. 浅谈系统架构<一>

    前言:博主刚刚从事于Web后端开发与学习不久,开发项目经验也是有限的.不过今天依旧将一些个人的想法记录下来,我的构想或许不太正确,还望各位大牛能给我多多建议. 首先:我们从编程开始讲起 博主是偏向于后 ...

  7. 从西直门立交桥谈IT架构与重构(干货)

    2015年8月13日 PM 20:00 Neeke君从一个战场奔赴至另一个战场,回到办公室,打开电脑,登陆微信,精彩的的微社群分享马上就要开始了! 大家好,我是Neeke,中文名高驰涛,PHP开发组成 ...

  8. iOS应用架构谈:架构设计的方法论

    缘由 之前安居客iOS app的第二版架构大部分内容是我做的,期间有总结了一些经验.在将近一年之后,前同事zzz在微信朋友圈上发了一个问题:假如问你一个iOS or Android app的架构,你会 ...

  9. 分布式还是混合式? 谈CDN架构对服务质量的影响

    传统分布式模型 通 常,内容分发网络(CDN)採用分布式模型.在这样的模型里, 用户的文件存放在一个源server上.而且由大量边缘server负责分发这些文件.这些边缘server的磁盘空间比較小. ...

随机推荐

  1. U盘安装kali中CDROM问题解决

    1,采用ultraISO 制作Kali的安装盘,无法安装.U盘不能被识别. 2,改用win32diskimager,能识别了,但期间出现CDROM找不到. 3,采用网上方式,ALT+ F2,ls /d ...

  2. 修改VScode行号区的背景颜色

    vs code是相当不错的一个编辑器,现阶段我用来编写nim程序. vs code非常丧心病狂一点就是行号区和编辑区的背景颜色都是一样, 这样会导致要看行首有没有对齐会非常吃力.这个问题让我纠结了非常 ...

  3. CC2640蓝牙芯片开发备记

    server ,characteristic UUID ,handle sever ,一个工程里可以有多个服务,按键服务,心率计服务,马达服务. characteristic , 一个服务可以有多个的 ...

  4. nc/netcat命令

    nc/netcat命令 语法 nc/netcat(选项)(参数) 选项 -g<网关>:设置路由器跃程通信网关,最多设置8个: -G<指向器数目>:设置来源路由指向器,其数值为4 ...

  5. 介质共享型局域网中的介质访问控制(MAC)协议需要具体解决的3个问题,CSMA/CD介质访问控制的基本思想

    1,在某一时刻,那个节点可以发送数据 2,发送时是否会出现冲突 3,出现冲突时如何处理 CSMA/CD介质访问控制的基本思想:先监听,再发送.边发送,边监听,如发生冲突,则等待一段时间后再次发送

  6. beifen

    Comparison of Models for Predicting the Outcome of Craniocerebral Injury by Using Machine Learning   ...

  7. npm ERR! Unexpected end of JSON input while parsing near...错误

    问题解决方案在GitHub中: https://github.com/vuejs-templates/webpack/issues/990 总结一下:1.删除package-lock.json 2.进 ...

  8. C语言---指针变量详解3

    指针可以指向一份普通类型的数据,例如 int.double.char 等,也可以指向一份指针类型的数据,例如 int *.double *.char * 等.如果一个指针指向的是另外一个指针,我们就称 ...

  9. 今天写代码遇到了一个BUG

    在我们日常写注释是需要注意,在有返回值的里面不要用以下方式注释,不然不会报错,运行状态码返回也是200,但就不是想要的结果. 下面举个例子 return { 'token':token, 'user_ ...

  10. 《Machine Learning Yearing》读书笔记

    ——深度学习的建模.调参思路整合. 写在前面 最近偶尔从师兄那里获取到了吴恩达教授的新书<Machine Learning Yearing>(手稿),该书主要分享了神经网络建模.训练.调节 ...