文档章节

花一天半写了个http暴力压测工具,每秒可轰出83万个http请求,支持pipeline

talent-tan
 talent-tan
发布于 07/10 15:20
字数 320
阅读 4049
收藏 44
点赞 7
评论 10

前因

windows下没什么太多好的http暴力压测工具,t-io在TFB上的表现也是前不前后不后的(见:https://my.oschina.net/talenttan/blog/1841863),所以特别想找个http暴力压测工具来找出tio-http的瓶颈,但是,暂时没有找到,所以想利用t-io自己动手写了一个。

后果
从昨天下午开始,到现在,大概一天半的时间,工具雏形已现,目前测出的最好数据是每秒处理70.7万个Http请求(前提是开启pipeline),见下图

show me the code
代码在:https://gitee.com/tywo45/t-io/tree/master/src/zoo/http/client

  • 先启动tio-http-server:org.tio.http.server.benchmark.TioBenchmarkStarter(代码在test目录)
  • 再启动tio-http-client:org.tio.http.client.HttpClientStarter

剩下的就没啥好讲的了,有兴趣的同学可以过来优化一下这个工具的展现层!

博客文字不在多,在于精,用极少的语言表达要表达的内容!
 

© 著作权归作者所有

共有 人打赏支持
talent-tan

talent-tan

粉丝 772
博文 27
码字总数 14342
作品 3
杭州
程序员
加载中

评论(10)

沙枣
沙枣
能不能做一个一秒过滤100万个无效 http 请求的程序
小肥肉
小肥肉
有一个东西叫JMater
刘建业
刘建业
有一个东西叫runloader。
talent-tan
talent-tan

引用来自“湖水没了”的评论

引用来自“talent-tan”的评论

引用来自“湖水没了”的评论

开始时间是不是该放在连接建立之后呢
对的,位置要调整下,你倒是很很仔细,竟然看了代码。

@talent-tan 没看tio-http的源码 只看了这里面解析http报文的部分 header body这些如果做成延迟解析的 性能应该高很多 用到了再解析 用不到就只做一个粗力度切割
有几个头是必须要解析出来的,content-type、content-length、connection(如果要兼容http1.0的话),张总回头在群里多提意见!
湖水没了
湖水没了

引用来自“talent-tan”的评论

引用来自“湖水没了”的评论

开始时间是不是该放在连接建立之后呢
对的,位置要调整下,你倒是很很仔细,竟然看了代码。

@talent-tan 没看tio-http的源码 只看了这里面解析http报文的部分 header body这些如果做成延迟解析的 性能应该高很多 用到了再解析 用不到就只做一个粗力度切割
talent-tan
talent-tan

引用来自“湖水没了”的评论

引用来自“talent-tan”的评论

引用来自“湖水没了”的评论

开始时间是不是该放在连接建立之后呢
对的,位置要调整下,你倒是很很仔细,竟然看了代码。

@talent-tan 不看代码怎么吸收精华啊
参与进来,完善一下展现层吧,哈哈。
湖水没了
湖水没了

引用来自“talent-tan”的评论

引用来自“湖水没了”的评论

开始时间是不是该放在连接建立之后呢
对的,位置要调整下,你倒是很很仔细,竟然看了代码。

@talent-tan 不看代码怎么吸收精华啊
talent-tan
talent-tan

引用来自“湖水没了”的评论

开始时间是不是该放在连接建立之后呢
对的,位置要调整下,你倒是很很仔细,竟然看了代码。
湖水没了
湖水没了
开始时间是不是该放在连接建立之后呢
旋律灬忧伤
业精于勤,戎码一生
t-io 3.0.3:TFB 压测被 actframework 碾压过后的简单抵抗

概述 上个版本有说tio参与了TFB测试,当时就说等着被大家看笑话,最新的测试结果出来了,果然排名比较靠后 1、json压测排名第176,每秒处理9.96万个http请求,知名国产框架act是排名第一,是...

talent-tan
06/20
0
1
Web 服务器基准测试,nginx+php vs Apache+php

本次测试nginx+php与apache+php哪种组合的计算性能及稳定性更佳 操作系统:Centos6.4 x64 硬件环境: 实验思路:在本次测试中打算采用,同版本组合测试,如(nginx1.4.4+php5.5.7)vs (httpd...

qw87112
2016/03/01
0
0
sumk-1.8.1 版更新,简单易用的互联网框架

sumk-1.8.1 发布,sumk 的定位是提供一个垂直版的类似于 spring boot 的互联网框架。它的生命线是开发速度和对互联网业务的支持 本次更新最突出的功能是测试接口。在测试模式下,所有对数据库...

游夏-sumk
05/02
0
0
滴滴打车 派单系统思考 数据库设计与PostgreSQL实现 - 2万元成本, 1天可盈利49亿

标签 PostgreSQL , 滴滴 , 派单 背景 打车类应用,如果完全按调度系统来派单,而非抢单的话,调度系统要非常的健硕。 比如滴滴打车,如何处理供给双方的需求,并高效的完成派单呢? 随着业务...

德哥
04/15
0
0
Jmeter压测快速体验

前言 最近在看neo4j相关的官网文档以及一些调优参数,同时也学了下Jmeter,为了测试下neo4j服务的性能,虽然不是专业搞测试的,但是我觉得每个优秀的开发者都应该学会主动压测自己服务和代码...

九劫散仙
2016/12/06
58
0
ApacheBench压测 那点事儿

摘要: 原创出处:www.bysocket.com 泥瓦匠BYSocket 希望转载,保留摘要,谢谢! “我总是希望自己不要过于草率地去批评一个人” -《傲慢与偏见》 写代码,到处是指标和数据的。在写完接口,为...

泥沙砖瓦浆木匠
2016/06/30
495
0
解决最后一公里-PTS铂金版发布数据工厂

PTS(Performance Testing Service)是web化、卓越的SaaS性能测试平台,具备强大的分布式压测能力,可模拟海量用户的真实业务场景。PTS铂金版的压力发起来源是遍布全国上百个城市和各运营商的...

云攻略小攻
04/10
0
0
微信公众号朋友圈压力测试

压力测试 详情页承载了朋友圈广告的主要内容,为保障用户的良好体验,需要对详情页所在服务器进行压力测试。 服务器部署及分类 详情页可以选择部署在腾讯服务器或广告主自己的服务器; 若广告...

xqtesting
2017/12/04
0
0
梁大帅/armyant

armyant(行军蚁) mqant压力测试工具 简介 armyant是从http压力测试工具hey改装而成。 hey只支持http接口的压力测试而armant可以自定义压测协议。 目前默认实现了http,mqtt两种协议的压力测试...

梁大帅
2017/12/09
0
0
性能测试相关知识小结

一个web请求的一般步骤 Web性能测试的部分概况一般来说,一个Web请求的处理包括以下步骤: 客户发送请求 web server接受到请求,进行处理; web server向DB/cache获取数据; webserver生成用...

rasine的杂货铺
2016/05/10
129
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

shell中的函数、shell中的数组、告警系统需求分析

shell中的函数 格式: 格式: function f_name() { command } 函数必须要放在最前面 示例1(用来打印参数) 示例2(用于定义加法) 示例3(用于显示IP) shell中的数组 shell中的数组1 定义数...

Zhouliang6
今天
2
0
用 Scikit-Learn 和 Pandas 学习线性回归

      对于想深入了解线性回归的童鞋,这里给出一个完整的例子,详细学完这个例子,对用scikit-learn来运行线性回归,评估模型不会有什么问题了。 1. 获取数据,定义问题     没有...

wangxuwei
今天
1
0
MAC安装MAVEN

一:下载maven压缩包(Zip或tar可选),解压压缩包 二:打开终端输入:vim ~/.bash_profile(如果找不到该文件新建一个:touch ./bash_profile) 三:输入i 四:输入maven环境变量配置 MAVEN_HO...

WALK_MAN
今天
0
0
33.iptables备份与恢复 firewalld的9个zone以及操作 service的操作

10.19 iptables规则备份和恢复 10.20 firewalld的9个zone 10.21 firewalld关于zone的操作 10.22 firewalld关于service的操作 10.19 iptables规则备份和恢复: ~1. 保存和备份iptables规则 ~2...

王鑫linux
今天
2
0
大数据教程(2.11):keeperalived+nginx高可用集群搭建教程

上一章节博主为大家介绍了目前大型互联网项目的系统架构体系,相信大家应该注意到其中很重要的一块知识nginx技术,在本节博主将为大家分享nginx的相关技术以及配置过程。 一、nginx相关概念 ...

em_aaron
今天
1
0
Apache Directory Studio连接Weblogic内置LDAP

OBIEE默认使用Weblogic内置LDAP管理用户及组。 要整理已存在的用户及组,此前办法是导出安全数据,文本编辑器打开认证文件,使用正则表达式获取用户及组的信息。 后来想到直接用Apache Dire...

wffger
今天
2
0
HFS

FS,它是一种上传文件的软件。 专为个人用户所设计的 HTTP 档案系统 - Http File Server,如果您觉得架设 FTP Server 太麻烦,那么这个软件可以提供您更方便的档案传输系统,下载后无须安装,...

garkey
今天
1
0
Java IO类库之BufferedInputStream

一、BufferedInputStream介绍 /** * A <code>BufferedInputStream</code> adds * functionality to another input stream-namely, * the ability to buffer the input and to * sup......

老韭菜
今天
0
0
STM 32 窗口看门狗

http://bbs.elecfans.com/jishu_805708_1_1.html https://blog.csdn.net/a1985831055/article/details/77404131...

whoisliang
昨天
1
0
Dubbo解析(六)-服务调用

当dubbo消费方和提供方都发布和引用完成后,第四步就是消费方调用提供方。 还是以dubbo的DemoService举例 -- 提供方<dubbo:application name="demo-provider"/><dubbo:registry address="z...

青离
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部