异数OS 织梦师-Xnign(四)-- 挑战100倍速Nginx,脚踩F5硬件负载均衡
.
异数OS 织梦师-Xnign(四)– 挑战100倍速Nginx,脚踩F5硬件负载均衡
本文来自异数OS社区
github: https://github.com/yds086/HereticOS
异数OS社区QQ群: 652455784
异数OS-织梦师(消息中间件 ,游戏开发方向)群: 476260389
异数OS-织梦师-Xnign(Nginx方向)群: 859548384
织梦师-Xnign 产品简介
异数OS 织梦师-Xnign 使用异数OS技术设计实现解除7层应用IO性能约束,带来http请求的10到100倍IO性能的提升,Xnign是Nginx的倒写,定位与Nginx目标类似,可以做Http cache静态页面加速,cgi可做精准L7业务负载均衡,可做大型网站前端流量接入,定制业务层精确分载。
与众不同的特性
- 简单的框架,实现简单,由于使用BIO方案,因此httpserver主框架代码仅30行,非常轻量级,复杂度仅有Nginx的万分之一。
- 高性能 ,由于异数OS 的IO加速,http请求处理性能是Nginx性能的100倍(静态页面cache 以及空负载cgi),实测每核长连接最大250W QPS,短连接120W QPS,最大带宽2.8GB/s(220WQPS),并发请求容量提升10倍,轻松实现300W活跃并发请求,理论推算可单路最大带200G双路400G网络流量。
- 方便定制 ,由于BIO以及RPC技术的简单易用,因此非常方便客户自行定制实现各类产品,技术难度降低很多。
- 精准业务层负载均衡方案, 通常的负载均衡方案可分为系统级负载均衡,比如F5 LVS,应用级负载均衡,比如Nginx,HAproxy,业务级负载均衡,比如消息队列,RPC等(rocketmq,dubbo),系统级负载均衡性能最高,但是负载均衡策略不够精确,通常是采集负载机系统的压力信息,如CPU 内存磁盘网络等资源占用来做负载均衡依据,但这类信息不能提前预警应用压力,通常发现时,目标负载系统已处于雪崩宕机的边缘,药石难救,因此受用面很窄,比如F5并不能为12306秒票业务做准确压力均衡分载,应用级负载均衡则相对更加准确,其可以收集目标应用的请求阻塞延迟情况来判断应用是否有过载可能,但其无法感知业务层负载,比如应用由于是分布式环境,其本身可能是空载,其CPU 以及IO都很空闲,但其业务请求队列可能已满载,后端数据库却在满载运行,这时再提交请求给应用,应用虽然能及时响应请求,但请求实际上都进入队列,这导致请求可能远远超时无法完成,因此业务级别的精确负载均衡成为更靠谱的需求,业务级负载均衡可以精准感知应用业务真实负载情况,根据真实业务负载压力,但一般的业务层负载均衡性能较低并发请求容量不足,并不能提供给门户站点入口使用,所以真正使用场合是在前面配合系统级负载均衡和应用级负载均衡构成三级负载均衡方案,这样就使得集群系统变的复杂并运维成本高昂,Xnign则通过高性能RPC技术以及消息队列技术为业务级负载均衡带来比系统级负载均衡高10倍的性能(F5 L7 CPS),因此大大降低负载均衡方案的运维成本和设计成本。
织梦师-Xnign 方案说明
1.HttpCreater 分布式环境中通过HttpCache提供的Rpc接口管理HttpCache,可以增删Xnign中HttpCache的静态页面.
2.HttpCache目前是一个静态页面的内存中的 HashMap。
3.HttpServer接收HttpClient的http请求,静态请求查询HttpCache并返回响应,cgi请求目前测试是个Echo,返回请求的cgi参数,未来会定制推送给业务的空闲Rpc线程,或者接入织梦师水母方案,以此实现精准的业务级负载均衡方案。
4. Rpc Manager为APP应用服务器提供RPC注册服务,APP应用服务器启动后在Rpc Manager注册关注的业务Topic,实现业务订阅,Rpc Manager为APP应用创建Rpc推送服务。
织梦师-Xnign测试成绩
测试项目分为静态页面的短连接性能测试,长连接性能测试,海量并发链接性能测试,理论每核最大带宽性能测试,cgi echo性能测试,测试环境都是单核2670v1 82599双口10G光纤 DPDK环境,HttpCache页面数量初始化为100W,请求池随机生成128K条,由于网卡条件约束,因此理论最大带宽测试使用异数OS软件交换机完成。
长连接128 Http请求线程400字节页面
长连接300W Http请求线程400字节页面
短连接128 Http请求线程400字节页面
短连接300W Http请求线程400字节页面
长连接128 Http请求线程1300字节页面理论带宽测试
2.8GB/s,理论单核可带满25G网卡,单节点预计带满200G,双节点400G。
长连接128 Http CGI请求线程Echo测试
相关性能对比
织梦师-Xingn 各项测试
测试特性 | 长连接128链接 | 长连接300W链接 | 短连接128并发线程请求 | 短连接300W并发线程请求 | 128线程长连接Cgi Echo |
---|---|---|---|---|---|
IOPS | 2.5M | 2.1M | 1.2M | 470K | 2.0M |
平均延迟 | 调用性能/链接数量 | 调用性能/链接数量 | 调用性能/链接数量 | 调用性能/链接数量 | 调用性能/链接数量 |
最小延迟 | 10us | 10us | 10us | 10us | 10us |
相关产品对比测试
数据来自网络,环境目标不同,选取目标产品最大性能值,成绩仅供参考。
引用的其他产品测试成绩
Nginx F-stack
https://github.com/F-Stack/f-stack
seastar 成绩引用
https://github.com/scylladb/seastar/wiki/HTTPD-benchmark
测试特性 | 织梦师-Xingn长连接 | 织梦师-Xingn短连接 | Seastar Httpd长连接 | F-stack Nginx短连接 (CPS) | F-stack Nginx长连接(RPS) | taomcat nio http | F5 VPR-LTM-C2400-AC(L7 CPS) |
---|---|---|---|---|---|---|---|
IOPS | 2.5M | 1.2M | 32W | 7W | 25W | 3000 | 100W(4核) |
平均延迟 | 调用性能/链接数量 | 调用性能/链接数量 | 调用性能/链接数量 | 调用性能/链接数量 | 调用性能/链接数量 | 调用性能/链接数量 | |
最小延迟 | 10us | 10us | 1-10ms | 1-10ms | 1-10ms | 1-10ms |
其他
通过上面对比测试,相对Nginx,织梦师-Xnign可加速Http请求100倍,并发请求性能提高10倍以上,HttpCache算是可以独立落地的产品了,有需要对静态页面加速的同学可以联系购买,需要L7业务级负载均衡定制的可加社区咨询合作开发。
异数OS 织梦师-Xnign(四)-- 挑战100倍速Nginx,脚踩F5硬件负载均衡的更多相关文章
- 异数OS 织梦师-云(五)-- 容器服务化,绿色拯救未来。
. 异数OS 织梦师-云(五)– 容器服务化,绿色拯救未来. 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652 ...
- 异数OS 织梦师-水桶(三)-- RAM共享存储方案
. 异数OS 织梦师-水桶(三)– RAM共享存储方案 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652455 ...
- 异数OS 织梦师-纤手(二)-- LPC RPC篇
异数OS 织梦师-纤手(二)– LPC RPC篇 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652455784 ...
- 异数OS 织梦师-水母(一)--消息队列篇
异数OS 织梦师-水母(一)–消息队列篇 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652455784 异数O ...
- 异数OS TCP协议栈测试(四)--网卡适配篇
异数OS TCP协议栈测试(四)–网卡适配篇 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 652455784 异 ...
- 异数OS国产CPU平台移植项目需求分析
异数OS国产CPU平台移植项目需求分析 目录 异数OS国产CPU平台移植项目需求分析 项目立项背景 项目需求分析 异数OS性能指标简介 1.TCP协议栈性能测试 2.异数OS-织梦师-水母 消息队列性 ...
- 异数OS 星星之火(三)--异数OS-织梦师云 微服务编写入门
. 异数OS 星星之火(三)–异数OS-织梦师云 微服务编写入门 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 6 ...
- 异数OS-织梦师-异数OS虚拟容器交换机(七) 走进4Tbps网络应用时代,加速5G应用真正落地
. 异数OS-织梦师-异数OS虚拟容器交换机(七) 走进4Tbps网络应用时代,加速5G应用真正落地 本文来自异数OS社区 github: https://github.com/yds086/Here ...
- 异数OS 星星之火(一)-- 异数OS-织梦师云 用户使用手册
. 异数OS 星星之火(一)– 异数OS-织梦师云 用户使用手册 本文来自异数OS社区 github: https://github.com/yds086/HereticOS 异数OS社区QQ群: 6 ...
随机推荐
- Total Commander 显示文件包含文件名扩展
在默认的 Total Commander 是分开文件名和文件扩展,如果想要让文件名同时显示扩展,可以通过设置合并文件名和扩展两列 点击配置,在选项的制表修改显示 How to configure To ...
- js 的this指向问题
this指向的,永远只可能是对象! this指向谁,永远不取决于this写在哪!而是取决于函数在哪调用. this指向的对象,我们称之为函数的上下文context,也叫函数的调用者. 1:通过函数名直 ...
- Blazor 服务端组件 Render, RenderFragment ,RenderTreeBuilder, CascadingValue/CascadingParameter
一.组件 支撑Blazor的是微软的两大成熟技术,Razor模板和SignalR,两者的交汇点就是组件.通常,我们从ComponentBase派生的类型,或者创建的.razor 文件,就可以称作组件. ...
- boostrap-非常好用但是容易让人忽略的地方【4】:Font Awesome
font-awesome基本用法 官方代码传送门 font-awesome在bootstrap中的特殊用法(这个才是重点) 要点归纳1(官方) 官方代码传送门 要点归纳2(我的) <a href ...
- LDO
1.出现原因:便携式设备的发展,使得人们对电源的要求越来越高,而以前一直使用的三段稳压电源无法满足需求. 2.特点:内部的PNP管导通压降很小,自耗很低. 3.应用场合: (1)不同电压输出级别的应用 ...
- CentOS 7 端口白名单设置
# 查看白名单列表 firewall-cmd --zone=public --list-ports # 添加白名单端口 firewall-cmd --zone=public --add-port=/t ...
- $Loj10157$ 皇宫看守 树形$DP$
loj Description 有一些宫殿,它们呈树形结构,相邻的宫殿之间可以互相望见.在一些宫殿设立士兵,使得所有的宫殿都有士兵或是被士兵望见.求最小士兵数. Sol 状态: f[x][0] 表示结 ...
- $loj10156/$洛谷$2016$ 战略游戏 树形$DP$
洛谷loj Desription Bob 喜欢玩电脑游戏,特别是战略游戏.但是他经常无法找到快速玩过游戏的方法.现在他有个问题. 现在他有座古城堡,古城堡的路形成一棵树.他要在这棵树的节点上放置最少数 ...
- Spring MVC 请求处理过程
1. 2. 3. 4. 5. 6.
- [MySQL实践] 实践记录
[MySQL实践] 实践记录 版权2019.5.17更新 MySQL MySQL各版本区别 一.选择的版本 1. MySQL Community Server 社区版本,开源免费,但不提供官方技术支持 ...