.

异数OS TCP协议栈测试(五)–关于QOS与延迟


##本文来自异数OS社区


github: https://github.com/yds086/HereticOS

异数OS社区QQ群: 652455784

异数OS-织梦师(消息中间件 ,游戏开发方向)群: 476260389

异数OS-织梦师-Xnign(Nginx方向)群: 859548384


关于TCP QOS以及延迟基本理论

本文讲述的是echo模式下的IO延迟与QOS,延迟是个比较敏感的话题,这也是异数OS直到今天才放出具体延迟数据的原因,因为这需要一个具体的业务场景才可以描述清楚延迟是什么,所以当Xnign稳定的提供服务后,我们才开始做具体的更有意义的延迟测试,Xngin是一个httpserver,因此延迟的理论计算很直白很简单,下面是延迟理论计算公式。

1.通常情况下,系统为所有并发服务提供均衡请求时(linux C10K时无法稳定提供)

平均延迟=(系统并发连接数量 /QPS) +(系统链路延迟).

2.当系统有QOS质量控制的情况下(linux无法提供)

平均延迟=(QOS队列中IO数量/QPS) +(系统链路延迟).

3.异数OS则在提供以上两种延迟方式基础上提供第三种延迟模式(linux无法提供)

最小延迟=(业务响应延迟/QPS) +(系统链路延迟) .

除去系统链路延迟(网卡交换机路由延迟),第一第二种模式,延迟都与系统并发数以及系统能够提供的QPS性能有直接关系,而第三种模式典型的业务响应延迟数值上可以认为是1,因此无论连接数量多少,都可以提供1/QPS的延迟,该模式可在海量链接时任然提供低延迟体验,这一方案唯有异数OS平台可提供,数据没有上,明白的私聊。

关于Xnign的实现以及测试代码可以在社区群共享获得。

Xnign延迟测试方案

异数OS软件交换机平台理论延迟测试

1.我们在system2启动两个容器,并分别启动Xnign服务,容器1 ip=192.36.0.51 qos=1,容器2 ip =192.36.0.101 qos=2,命令如下

S2-C1: (list (StartService Xnign “-qosid=1”) )

S2-C2: (list (StartService Xnign “-qosid=2”) )

2.在system4启动两个容器,其中容器2启动4个命令控制模式XnignTest,分别对应链接不同qos下的两个Xnign,命令如下

S4-C2: (list (StartService XnignTest “-dip=192.36.0.51 -qosid=1 -ctl”))

S4-C2: (list (StartService XnignTest “-dip=192.36.0.51 -qosid=2 -ctl”))

S4-C2: (list (StartService XnignTest “-dip=192.36.0.101 -qosid=1 -ctl”))

S4-C2: (list (StartService XnignTest “-dip=192.36.0.101 -qosid=2 -ctl”))

创建的服务:

3.测试两个Xnign的延迟,

S4-C2: (ServiceInput 1 “-pc=10 -lp -start”)

S4-C2: (ServiceInput 1 “-pc=10 -sp -start”)

S4-C2: (ServiceInput 3 “-pc=10 -lp -start”)

S4-C2: (ServiceInput 3 “-pc=10 -sp -start”)

结果:

延迟数据单位为ns,可以看出长连接平均延迟为1us,短连接平均延迟2.5us,注意由于我们开启了两个Xnign并占用两个Qos队列,因此当system上只有一个Xnign时,延迟测试数据只有该数据一半左右,另外延迟统计算法大概占用200ns左右没有剔除。

  1. 给ip=192.36.0.51 qos=1的Xnign服务一个100W并发长链接的循环压测测试

    S4-C1: (list (StartService XnignTest “-dip=192.36.0.51 -c=1000000 -qosid=1”))

100W长链接循环压测,平均延迟570ms。

5.回到S4-C2,再分别测试下两个Xnign的服务延迟

S4-C2: (ServiceInput 1 “-pc=10 -lp -start”)

S4-C2: (ServiceInput 1 “-pc=10 -sp -start”)

S4-C2: (ServiceInput 2 “-pc=10 -lp -start”)

S4-C2: (ServiceInput 2 “-pc=10 -sp -start”)

S4-C2: (ServiceInput 3 “-pc=10 -lp -start”)

S4-C2: (ServiceInput 3 “-pc=10 -sp -start”)

S4-C2: (ServiceInput 4 “-pc=10 -lp -start”)

S4-C2: (ServiceInput 4 “-pc=10 -sp -start”)

得到结果:



可以看出由于100W压测链接影响,S2-C1的Xnign服务器延迟已经比较高了,其中短连接几乎测试失败,长连接则稳定在确定的570ms延迟上,而S2-C2的Xnign由于在Qos2上,因此还能正常低延迟访问。

wrk linux 无优化环境压测

压测客户端为千兆网卡,linux环境,内网无丢包,成绩大概2线程 9W QPS,120us平均延迟,该测试主要被linux本身性能约束,并不反映Xnign服务端的最大性能容量,实际上wrk 16CPU核16线程压测Xnign时,异数OS CPU占用率仅3%,而此时linux wrk已16核满载,成绩却下降到1W QPS,反复测试几次后linux wrk出现无法响应问题,杀掉进程重启wrk任然无响应,netstat显示无异常链接,此时windows浏览器任然可以打开页面,XnignTest压测任然正常,由于异数OS作者并不懂linux 优化,所以测试没有再继续深入,wrk使用保持长连接,短链接由于TIME_WAIT状态问题所以没有参考意义,请求数达到28231后wrk停止响应。



linux wrk异常后windows浏览器的反馈。

82599网卡4%丢包环境测试

下面两项为82599网卡4%丢包环境测试, 4%丢包可以用于模拟广域网高延迟高错误的情况,更能挑战反应协议栈以及上层应用的容错能力,稳定性,通讯延迟,链接活跃保持能力等,压测端使用XnignTest。

XnignTest压测 2W保持链接

196W QPS ,平均10ms,最小40us,正态分布统计99%在115ms中完成,超出400ms以上IO延迟约占0.15%

XnignTest压测 1链接

该测试用于直观分析单个链接的性能表现,可以看到大概1000QPS,平均1ms,最小10us,最大100ms。

这两项82599 4%丢包环境测试可以看到Xnign任然保持着0错误和100%的链接活跃可用,当然QPS性能损失还是有,20000链接时损失20%的性能从230WQPS下降到190W左右,单链接QPS性能则从10W QPS下降到1000,但即便是低延迟要求的游戏而言1000的QPS,100ms最大延迟平均1ms延迟也是完全够用的。

异数OS TCP协议栈测试(五)--关于QOS与延迟的更多相关文章

  1. 异数OS TCP协议栈测试(四)--网卡适配篇

    异数OS TCP协议栈测试(四)–网卡适配篇 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652455784 异 ...

  2. 异数OS TCP协议栈测试(三)--长连接篇

    异数OS TCP协议栈测试(三)--长连接篇 本文来自异数OS社区 github:   异数OS-织梦师(消息中间件)群: 476260389 异数OS TCP长连接技术简介 说起长连接,则首先要谈对 ...

  3. 异数OS TCP协议栈测试(二)--短连接篇

    异数OS TCP协议栈测试(二)--短连接篇 本文来自异数OS社区 github:   异数OS-织梦师(消息中间件)群: 476260389 测试目标 TCP 短链接IO性能测试,Client Se ...

  4. 异数OS TCP协议栈测试(一)--数据传输篇

    异数OS TCP协议栈测试(一)--数据传输篇 本文来自异数OS社区 github:   异数OS-织梦师(消息中间件)群: 476260389 测试目标 数据传输IO性能测试,主要是建立连接后测试收 ...

  5. 异数OS国产CPU平台移植项目需求分析

    异数OS国产CPU平台移植项目需求分析 目录 异数OS国产CPU平台移植项目需求分析 项目立项背景 项目需求分析 异数OS性能指标简介 1.TCP协议栈性能测试 2.异数OS-织梦师-水母 消息队列性 ...

  6. 国产CPU 申威1621 异数OS基础组件理论性能测试报告

    国产CPU 申威1621 异数OS基础组件理论性能测试报告 文章目录 国产CPU 申威1621 异数OS基础组件理论性能测试报告 前言 测试平台 测试项目 SW1621 异数OS 容器虚拟交换机模拟性 ...

  7. 异数OS 织梦师-水桶(三)-- RAM共享存储方案

    . 异数OS 织梦师-水桶(三)– RAM共享存储方案 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652455 ...

  8. 异数OS 织梦师-纤手(二)-- LPC RPC篇

    异数OS 织梦师-纤手(二)– LPC RPC篇 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652455784 ...

  9. 异数OS 2017 DPDK 峰会观后感

    1.DPDK in Container 使用虚拟网卡设备技术为每一个容器分配一个IP 网卡适配器(queue).容器技术可以解决虚拟机技术中虚拟机过于臃肿,难于热迁移的问题,可能可以代替美团OVS方案 ...

随机推荐

  1. JAVA核心知识点--打包 FatJar 方法小结

    目录 什么是 FatJar 三种打包方法 1. 非遮蔽方法(Unshaded) 2. 遮蔽方法(Shaded) 3. 嵌套方法(Jar of Jars) 小结 参考阅读 原文地址:https://yq ...

  2. C# 性能分析 反射 VS 配置文件 VS 预编译

    本文分析在 C# 中使用反射和配置文件和预编译做注入的性能,本文的数据是为预编译框架,开发高性能应用 - 课程 - 微软技术暨生态大会 2018 - walterlv提供 本文通过代码生成工具,使用C ...

  3. HDU - 5015 233 Matrix (矩阵快速幂)

    In our daily life we often use 233 to express our feelings. Actually, we may say 2333, 23333, or 233 ...

  4. 【53.57%】【codeforces 610C】Harmony Analysis

    time limit per test3 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  5. 新书《iOS编程(第6版)》抢鲜试读

    我最近翻译了Big Nerd Ranch的<iOS编程(第6版)>.我用了大半年时间,尽可能做到通顺易懂.不足之处请大家多多指正.感谢辛苦审校的丁道骏同学. 这本书得过Jolt大奖,原书在 ...

  6. Vijos1774 机器翻译 [模拟]

    1.题意:给定一段长度为N个单词的文章(一个单词用一个非负整数表示),可以使用一个容量为M个元素的容器.你的任务是使用字典的帮助翻译文章,遇到一个单词,查询之后将此单词的释义放入容器中,下次遇到时若此 ...

  7. F#周报2019年第51&52期

    新闻 介绍DataFrame 介绍System.Threading.Channels ConfigureAwait常见问题 第三次年度C#降临节 .NET会议--2020年1月14日 如何找到F#的工 ...

  8. UVW平台运动控制算法以及matlab仿真

    UVW平台运动控制算法以及matlab仿真   最近公司同事因为对某视觉对位平台的运动控制算法有疑问,所以来请教我.由于我也是第一次接触到UVW自动对位平台(也可以叫XXY自动对位平台),于是找了一些 ...

  9. CodeForces - 786B -- 线段树优化建图

    刚开始想了两个小时,打算把区间分块然后计算,但是这就很灵性了看了一个大佬的博客,侵删 #include<cstring> #include<iostream> #include ...

  10. $[NOIp2017]$ 宝藏 状压$dp$

    \(Sol\) 觉得这里是个很巧妙的地方吖,就是记下当前扩展点集的最大深度,然后强制下一步扩展的点集都是最大深度+1.这样做在当前看可能会导致误算答案导致答案偏大,但是整个\(dp\)完成后一定可以得 ...