交易系统【三】网关

第二章本来是要讲消息总线,审核说是过度宣传,就放弃了,不纠结,先跳过。

网关和消息总线的底层技术都和网络相关,两者也有很重要的差别。消息总线主要用于内网,受交换机和网卡影响比较大,网络状况也比较稳定,网络重传的概率低,为了追求低延迟,软硬件技术非常苛刻。

网关和消息总线有很大不同,它主要面向互联网,交易所通常会要求专线接入,网络状况要优于互联网,但距离的缘故,网络延迟本身就远高于局域网。想象下,光每纳秒也只能传播30厘米,就知道距离对延迟的影响有多大。上海城内平均延迟在10毫秒,上海到北京之间城域网,延迟也要超过30毫秒。另一方面,长距离传输要跳转多个交换机,丢包率就要高于局域网。在这种场景下,网关的技术核心就不是怎么将延迟降到微秒级别,没有意义,而是在处理好不稳定的网络状况后,保证业务的持续性。

因为互联网本身固有的延迟,网关延迟要远高于内网的消息总线,但并不意味着网关的延迟控制不重要,在技术上也很容易。网关要处理的连接数通常要远高于消息总线,网络吞吐量也高于消息总线几个数量级。想象下,中国三亿股民,一只股票行情数据在消息总线上只需要传输几份副本,而将这个行情数据推送给客户端,网络传输的数据量得有多大。这个例子有点夸张也不准确,只为说明数量级的差距。交易所通常采用多级分发的策略,由交易所到证券席位和行情供应商,再由他们分发。

除了网络吞吐量大外,网关还要应对流量尖峰。一旦瞬间网络流量超过操作系统缓冲大小,超过运营商带宽,或者经过的交换机问题,都有可能被丢弃,导致网络重传,一旦触发超时机制,延迟都不会太小。

以上这些问题,是网关的共性技术问题,如何解决有不少优秀产品和技术可以借鉴。交易系统的网关在稳定性要求更加严格,在业务上也有特有的需求,比如交易网关,行情网关,结算网关,甚至股票和债券交易网关都可以分割开。

安全性考虑,将网关和核心网络隔离,防止重复登录,双向心跳侦测网络故障更及时。成交回报的推送除了避免网络上丢失,业务层面也要加入重传机制。

交易系统是时间敏感的,网关和终端之间日历和时钟同步也是至关重要。日历对延迟容忍性要高点,时钟就苛刻的多,传统的NTP误差在毫秒级,随着交易频率越来越高和交易公平性的要求,对时间精度越来越高。撮合原则除了价格优先还有时间优先,简单的做法以到达撮合系统来标记时间优先顺序,这种做法受到传输距离影响比较大,高频量化系统就把服务器搬到交易所机房,减少传输距离,拿到时间优先权,更公平的做法是以委托单到交易所的前置机为准。有的交易所会采用GPS时钟源,早期有报道称,谷歌在数据中心内部采用原子钟作为跨数据中心时钟同步基准,不知道现在交易所有没有应用。GPS时钟加原子钟,这两种技术混用,以物理世界的真实时间,大大降低了传输距离导致的排序偏差,也降低了技术难度。

前置机和网关之间的断网重连机制也是网关要考虑的重点,毕竟网络状况是不可预测的。前置机在断网后有可能连接失败,或者重连后可能连接到其他网关。交易系统如何避免重单,在前置机重连后,之前的网关数据如何处理,是业务级别策略。网关是被动接受连接,断网重连不是技术上难题。

网关除了网络流量控制外,还要考虑业务上的流速控制,避免某个前置机发单过多,而其他前置机处于饥饿状态,这是技术导致业务上的不公平。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/73378.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

eNSP中路由器的CON/AUX接口、GE Combo接口、Mini USB接口、USB接口、WAN侧uplink接口、FE接口、GE接口介绍

路由器常见接口的详细介绍及其应用示例: 1. CON/AUX 接口 全称:Console/Auxiliary(控制台/辅助接口)作用: CON(Console):通过命令行界面(CLI)直接配置路由器…

iOS底层原理系列04-并发编程

在移动应用开发中,流畅的用户体验至关重要,而并发编程是实现这一目标的关键技术。本文将深入探讨iOS平台上的并发编程和多线程架构,帮助你构建高性能、响应迅速的应用程序。 1. iOS线程调度机制 1.1 线程本质和iOS线程调度机制 线程是操作…

Vmware下的openEuler

1.下载openEuler操作系统镜像 https://repo.openeuler.org/openEuler-20.03-LTS/ISO/ 2.在VM新建虚拟机 3.虚拟机联网 我是出现了没有网络,ping不通的问题 参考:https://blog.csdn.net/FHY26828/article/details/140941234 修改文件: 在…

带宽管理配置实验

一、实验拓扑 配置流程: 1、带宽通道:整体带宽、每个用户带宽、连接数、优先级信息 2、带宽策略 3、策略通道,引用 4、配置接口出入带宽 二、实验需求和配置 1、基础配置 接口配置 [dianxin]interface GigabitEthernet 0/0/0 [dianxin-G…

【STM32】从新建一个工程开始:STM32 新建工程的详细步骤

STM32 开发通常使用 Keil MDK、STM32CubeMX、IAR 等工具来创建和管理工程。此处是 使用 Keil MDK5 STM32CubeMX 创建 STM32 工程的详细步骤。 新建的标准库工程文件已上传至资源中,下载后即可直接使用。 标准库新建 STM32 工程的基本目录结构:STD_STM…

探索 Trossen AI:从 Aloha到智能机器人平台的进化之路

在人工智能与机器人技术快速发展的当下,科研硬件的性能与成本成为影响行业创新的重要因素。Trossen Robotic为在机器人领域二十余年的知名企业,近日推出的 Trossen AI 系列产品,为科研机构与开发者提供了高性能、高性价比的解决方案。 Trosse…

C语言:5.20程序练习题

打印一个菱形图案。程序分为两部分&#xff1a;上半部分和下半部分。上半部分打印一个逐渐增大的星号图案&#xff0c;下半部分打印一个逐渐缩小的星号图案。 #include<stdio.h> int main() {int row 5;//定义行数int t 2;for (int i row; 0 < i; i--){for (int k…

一些docker命令

一、基础命令 查看 Docker 版本 docker --version 或 docker version&#xff1a;显示 Docker 客户端和服务器的版本信息。 查看 Docker 系统信息 docker info&#xff1a;显示 Docker 系统的详细信息&#xff0c;包括镜像、容器数量、存储驱动类型等。 Docker 服务管理 s…

C语言内容

C语言是一门经典且广泛应用的编程语言&#xff0c;具有以下基础要点&#xff1a; 基本数据类型 包括整型&#xff08;如 int &#xff09;、字符型&#xff08; char &#xff09;、浮点型&#xff08; float 和 double &#xff09;等&#xff0c;用于定义不同类型的变量来…

Python----数据可视化(Pyecharts一:介绍安装,全局配置,系列配置)

一、PyEcharts介绍 1.1、概况 Echarts 是一个由百度开源的数据可视化&#xff0c;凭借着良好的交互性&#xff0c;精巧的图表设计&#xff0c;得到了众多开发者的认可。而 Python 是一门富有表达力的语言&#xff0c;很适合用于数据处理。当数据分析遇上数据可视化时&#xff…

dockerfile 编写入门

Dockerfile编写指南 Dockerfile是一个文本文件&#xff0c;其中包含了一系列的指令和参数&#xff0c;用于定义如何构建Docker镜像。一个良好编写的Dockerfile不仅可以确保镜像的构建过程高效、可靠&#xff0c;还可以使得镜像更加安全和易于维护。 1. Dockerfile基本结构和语…

Git 本地常见快捷操作

Git 本地常见快捷操作 &#x1f4cc; 1. 基本操作 操作命令初始化 Git 仓库git init查看 Git 状态git status添加所有文件到暂存区git add .添加指定文件git add <file>提交更改git commit -m "提交信息"修改最后一次提交信息git commit --amend -m "新…

如何处理PHP中的文件上传错误

如何处理PHP中的文件上传错误 在Web开发中&#xff0c;文件上传是一个常见的功能需求。然而&#xff0c;文件上传过程中可能会遇到各种错误&#xff0c;如文件大小超出限制、文件类型不被允许、上传过程中断等。为了确保用户能够顺利上传文件&#xff0c;并且开发者能够有效地…

Linux--普通文件的管理

目录 1、创建根目录结构中的所有的普通文件 2、列出所有账号的账号名 3、将/etc/passwd中内容按照冒号隔开的第三个字符从大到小排序后输出所有内容 4、列出/etc/passwd中的第20行-25行内容 head命令 tail命令 5、切割出你的ip地址和mac地址 ip地址 MAC地址 6、切割…

【SpringMVC】常用注解:@RequestBody

1.作用 用于获取请求实体内容&#xff0c;直接使用得到的是keyvalue&keyvalue的数据。获取请求实体内容不适用get请求。 2.属性 required 描述是否有请求体&#xff0c;默认值为true。当取值为true时&#xff0c;get 请求方式会报错。如果取值为false&#xff0c;get请…

RK3588 远程 SSH时出现WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!

WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! 翻译过来就是 警告&#xff1a;远程主机标识已更改&#xff01; 此报错是由于远程的主机的公钥发生了变化导致的。 ssh服务是通过公钥和私钥来进行连接的&#xff0c;它会把每个曾经访问过计算机或服务器的公钥&#xff…

Go红队开发—web网络编程

文章目录 web网络编程Req快速请求 调试DevModeDebugLogTraceInfo瓶颈分析 控制请求与响应控制请求的字段内容控制调试打印的内容分开dump请求与响应部分请求体设置 作用范围级别设置参数查询URL 路径参数表单请求设置请求头设置 判断响应状态码解析数据SetSuccessResultgjson响…

PawSQL for TDSQL:腾讯云TDSQL数据库性能优化全攻略

TDSQL 作为腾讯云推出的分布式数据库&#xff0c;凭借其高扩展性、高可用性和高性能等优势&#xff0c;广泛应用于金融、互联网、政务等领域。随着业务的不断增长和数据量的爆炸式增长&#xff0c;如何优化 TDSQL 数据库的性能&#xff0c;成为众多企业和开发者面临的挑战。本文…

67.Harmonyos NEXT 图片预览组件之性能优化策略

温馨提示&#xff1a;本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦&#xff01; Harmonyos NEXT 图片预览组件之性能优化策略 文章目录 Harmonyos NEXT 图片预览组件之性能优化策略效果预览一、性能优化概述1. 性能优化的关键指标…

C语言中的字符串与数组的关系

在C语言中,字符串和数组之间有着紧密的关系。理解它们的区别和联系对于编写高效且可靠的代码至关重要。在本篇博文中,我们将详细分析字符串和数组在C语言中的概念、它们的关系以及如何在编程中应用它们。 一、字符串与数组的基础知识 1.1 数组概念 在C语言中,数组是一组相…