为了保证实盘交易程序能够正常稳定地运行,同时保护您在使用时账户资金的安全,我们设计了一些规则和机制。了解这些机制有助于您更快上手实盘交易。

启动前检查机制

在实盘交易程序启动前,系统会执行一次检查,出现以下异常时实盘不可启动:

  • 若当前实盘所对应的API key或策略已被删除,则当前实盘不能启动;
  • 同一个API key对应的实盘交易程序同时最多只能有一个在运行,若当前实盘所配置的API key已被其他运行中实盘占用,则该实盘不能启动;
  • 为保证账户资金安全,只有运行过回测的策略才能运行实盘,您可以参考回测结果来决定是否运行该策略的实盘。

运行保护机制

运行中(或着正在执行启动前检查)的实盘,不能更改当前实盘的策略&API key配置,且当前配置的策略&API key被锁定,无法进行编辑或删除操作,直到实盘停止运行时解锁。

异常停止机制

当实盘交易程序在运行过程中遇到以下异常情况时,默认会报错并自动停止运行:

  • 在启动实盘时,若检测到策略代码本身有语法、格式等方面的错误,系统会报错并启动失败;
  • 当实盘程序运行过程中遇到运行时错误,系统会报错并停止实盘;
  • 当实盘运行过程中检测到API key失效时,系统会报错并停止实盘;
  • 当实盘程序运行过程中获取到的行情推送延迟过高时,为了防止延迟导致错过合适的交易时间(延迟超过frequency周期时甚至会触发错误的交易信号)导致用户损失,系统会报错并自动停止实盘程序;
  • 为了简化运算场景、避免计算异常,实盘程序每次执行handle_data函数时都会检测账户资金情况,若含有有冻结资产、含有借贷、含有非策略指定交易品种持仓时,系统都会报错并自动停止实盘程序;
  • 实盘程序运行过程中,在每一次新的frequency周期到来之前都会先取消当前frequency周期内发起但未完成的订单委托,以免出现重复下单的情况,若发生订单取消超时的情况(基本不会遇到),系统会报错并停止实盘程序。

以上这种严格的异常停止机制能够在最大程度上保证实盘运行的准确性和安全性,但也在一定程度上丧失了连续性和容错能力。所以我们额外提供了实盘运行异常时的自动重启和错误恢复功能,从而实现实盘程序持续长久托管运行,您可以在新建/设置实盘交易时自行选择是否开启(默认不开启)。以下是两个功能的介绍:

自动重启功能

用户开启自动重启选项以后,若实盘运行过程中因出现异常而自动停止,则系统会在实盘停止24小时内不断尝试重启,直到该实盘启动成功正常运行为止。重启作为一个新的实盘运行实例,与启动实盘策略逻辑相同(从下一个frequency周期开始运行,输出日志有重启提示,并推送启动通知),目前不保留中间状态。下次停止时如果自动重启选项开启,则重新计时,相同操作。用户点击停止则不会触发重启。(注:这个功能不能完全保证实盘策略执行的连续性,如果用户实盘是在frequency周期的末尾临界时间结束并退出,跨frequency周期重启时,由于是等待下一个frequency周期到达,则会出现跳frequency周期的执行,因此,这个功能不是万能的。所以有了下边个功能设计。)

错误恢复功能

用户开启错误恢复选项以后,则实盘在运行过程中出现异常并不会立刻停止运行, 而是会保留现有的运行时上下文,等待下一个frequency周期到达后(如果行情推送没有按时到达,则记为一次恢复失败,继续等待下一个frequency周期),执行新的handle_data()函数(上一个handle_data函数已经执行完毕,或已经被Kill)。(这里需要注意潜在运行风险,如果用户依赖历史运行状态,例如通过user_data来计算趋势,则在跳过上一个frequency周期,直接运行下一个frequency周期的handle_data函数时候,可能会使趋势的判断不准确,造成策略异常。)错误恢复时,会对现有的订单记录、持仓记录进行合并,缺失的分析指标基础数据会进行插值,输出错误恢复日志,并附带错误恢复计数。每一次错误恢复,错误计数加1,连续5次错误恢复就错误恢复计数为5,第六次错误恢复不进行恢复,直接退出。如果错误恢复成功,则错误计数清零。

停止保护机制

无论是您手动停止实盘,还是实盘运行中出错自动停止,系统都会在停止时撤销您当前委托中的订单,以免造成损失。(当您的实盘程序是因API key失效导致自动停止时,系统无法撤销您当前委托中的订单)

WeQuant教程—1.5 实盘运行须知的更多相关文章

  1. Android Studio系列教程二--基本设置与运行

    Android Studio系列教程二--基本设置与运行 2014 年 11 月 28 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处! 上面一篇博客,介绍了Studio的 ...

  2. iOS 11开发教程(三)运行第一个iOS 11程序

    iOS 11开发教程(三)运行第一个iOS 11程序 运行iOS11程序 创建好项目之后,就可以运行这个项目中的程序了.单击运行按钮,如果程序没有任何问题的话,会看到如图1.6和1.7的运行效果. 图 ...

  3. gradle-rn-app工程运行须知

    singwhatiwanna edited this page 16 days ago · 5 revisions  Pages 7 Home Demo 工程运行须知 VirtualAPK API 概 ...

  4. WeQuant教程—1.4 实践教学:比特币量化定投

     在wequant.io,为了让读者能直接体验量化系统的魅力,我们用前面的思路,实现了一套完整的量化系统和回测工具,这个系统非常简单,用户只需要把交易意志用策略表达出来,系统就可以自己完成交易效果的回 ...

  5. WeQuant教程—1.3 利用回测工具降低交易风险

    量化系统投入实际使用之前,人们会希望提前测试交易的效果.这个期间往往涉及代码的改动和参数的调整.最常见的做法是将历史数据输入量化系统,让量化系统根据既定的交易逻辑进行操作,观察和分析交易结果,找到问题 ...

  6. 1、CC2541蓝牙4.0芯片中级教程——基于OSAL操作系统的运行流程了解+定时器和串口例程了解

    本文根据一周CC2541笔记汇总得来—— 适合概览和知识快速索引—— 全部链接: 中级教程-OSAL操作系统\OSAL操作系统-实验01 OSAL初探 [插入]SourceInsight-工程建立方法 ...

  7. 《自拍教程52》Python_adb运行Shell脚本

    Android作为一款Linux终端,肯定是支持.sh后缀的Shell脚本的运行的, 有时候测试环境准备或者长时间截取复杂的日志等,开发会给到一些Shell脚本. Shell脚本的执行的优势: 快捷高 ...

  8. 2021升级版微服务教程5—通过IDEA运行多个项目实例「模拟集群」

    2021升级版SpringCloud教程从入门到实战精通「H版&alibaba&链路追踪&日志&事务&锁」 教程全目录「含视频」:https://gitee.c ...

  9. Java教程——CMD手动编译运行失败原因(高手略过)

    (仅对新手,高手略过)在学习Java初期,我们在利用cmd手动编译java程序的时候,会遇到编译成功,但运行却总是提示失败.已经排除了java配置环境的问题,Path和ClassPath以及%JAVA ...

随机推荐

  1. js事件2-事件兼容问题

    对于不同的浏览器,事件响应会有一定的不同,所以我们为了更好的用户效果,必须要考虑好事件兼容性问题. 为了兼容不同的浏览器,我们可以自己编写一个事件对象,通过它的事件添加函数和删除函数来给元素添加/删除 ...

  2. 洛谷【P1498】:南蛮图腾(分治算法)

    传送门 题目描述就不用看了,直接上样例就行: 输入样例#1: 2 输出样例#1: /\ /__\ /\ /\ /__\/__\ 输入样例#2: 3 输出样例#2: /\ /__\ /\ /\ /__\ ...

  3. SparkStreaming运行原理

    Spark Streaming应用也是Spark应用,Spark Streaming生成的DStream最终也是会转化成RDD,然后进行RDD的计算,所以Spark Streaming最终的计算是RD ...

  4. vue发送websocket请求和http post请求

    直接上代码: pdf.vue <script> import SockJS from 'sockjs-client'; import Stomp from 'stompjs'; impor ...

  5. UI与数据的绑定

    核心是数据变化跟踪与UI更新的问题 概念整理: 供业务使用的叫数据: 供UI使用的叫状态: UI的变化能被监听到: 数据的变化能实时反映到UI上: 数据变化—>拦截—〉UI状态重置—>UI ...

  6. Ansible自动部署tomcat

    1.首先准备3台机器 ansible机器:192.168.52.34 目标主机:192.168.52.35 目标主机:192.168.52.36 2.关闭防火墙 [root@localhost ~]# ...

  7. python函数 | 列表生成式

    在编写程序或者查看别人的程序时,经常会遇到列表生成式,这个使用起来并不复杂,但是非常有用,使我们的代码更加简洁灵活.很多python使用者并不太会使用它.今天,就给大家详细讲解列表生成式和生成器表达式 ...

  8. yugabyte 安装pg extention

    前段时间在学习yugabyte 发现yugabyte 是直接复用了pg server的源码,所以当时就觉得大部分pg extension 也是可用. 今天看到了官方文档中有关于如何安装的,发现还得多看 ...

  9. JS的ES6的iterator

    一.iterator 1.概念:iterator是一种接口机制,为各种不同的数据结构提供统一的访问机制. 2.作用: 为各种数据结构,提供一个统一的.简便的访问接口: 使得数据结构的成员能够按某种次序 ...

  10. REdis一致性方案探讨

    REdis功能强大众所周知,能够大幅简化开发和提供大并发高性能,但截止到REdis-5.0.5仍然存在如下几大问题: 一致性问题 这是由于REdis的主从复制采用的是异步复制,异常时可能发生主节点的数 ...