From 9c242ed73f3a328754714228d2ef8c6950eb6bdf Mon Sep 17 00:00:00 2001 From: "vn.py" Date: Thu, 15 Feb 2018 15:45:06 +0800 Subject: [PATCH] =?UTF-8?q?[Add]=E5=A2=9E=E5=8A=A0WebTrader=E7=9A=84?= =?UTF-8?q?=E6=96=87=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- examples/README.md | 2 ++ examples/WebTrader/README.md | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+) create mode 100644 examples/WebTrader/README.md diff --git a/examples/README.md b/examples/README.md index cb7a61bf..0739e3f2 100644 --- a/examples/README.md +++ b/examples/README.md @@ -6,6 +6,8 @@ * OptionMaster: 期权量化交易系统 +* WebTrader:使用Web前端作为监控的交易系统 + * DataRecording:全自动行情记录工具(无需用户每日定时重启) * CtaTrading:无图形界面模式的CTA策略交易 diff --git a/examples/WebTrader/README.md b/examples/WebTrader/README.md new file mode 100644 index 00000000..f81fa472 --- /dev/null +++ b/examples/WebTrader/README.md @@ -0,0 +1,34 @@ +# WebTrader使用说明 + +## 使用步骤 + +1. 修改CTP_connect.json中的账号和服务器地址 +2. 修改WEB_setting.json中的网页登录用户名和密码 +3. 打开cmd,运行python server.py +4. 打开另一个cmd,运行python run.py +5. 用浏览器(推荐Chrome)访问http://localhost:5000/ +6. 输入2中的用户名和密码登录后,点击左下角的“连接CTP” +7. 网页前端的使用方法和常规版本的VnTrader基本一致 +8. 如需运行CTA策略,请修改CTA_setting.json中的配置 + +## 文件功能 + +* server.py:基于vnpy.rpc模块实现的交易服务器,包含CTP接口和CTA策略模块 +* run.py:基于Flask实现的Web服务器,内部通过vnpy.rpc客户端来访问交易服务器 + +## 架构设计 + +* 基于Flask-Restful实现的主动函数调用功能,数据流程: + 1. 用户点击浏览器中的某个按钮,发起Restful功能调用 + 2. Web服务器收到Restful请求,将其转化为RPC功能调用发送给交易服务器 + 3. 交易服务器收到RPC请求,执行具体的功能逻辑,并返回结果 + 4. Web服务器返回Restful请求的结果给浏览器 + +* 基于Flask-Socketio实现的被动数据推送功能,数据流程: + 1. 交易服务器的事件引擎转发某个事件推送,并推送给RPC客户端(Web服务器) + 2. Web服务器收到事件推送后,将其转化为json格式,并通过Websocket发出 + 3. 浏览器通过Websocket收到推送的数据,并渲染在Web前端界面上 + +* 将程序分为两个进程的主要原因包括: + 1. 交易服务器中的策略运行和数据计算的运算压力较大,需要保证尽可能保证低延时效率 + 2. Web服务器需要面对互联网访问,将交易相关的逻辑剥离能更好保证安全性 \ No newline at end of file