文档章节

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

talent-tan
 talent-tan
发布于 07/10 15:20
字数 320
阅读 4893
收藏 55

前因

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

粉丝 828
博文 30
码字总数 15014
作品 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

没有更多内容

加载失败,请刷新页面

加载更多

如何通过 J2Cache 实现分布式 session 存储

做 Java Web 开发的人多数都会需要使用到 session (会话),我们使用 session 来保存一些需要在两个不同的请求之间共享数据。一般 Java 的 Web 容器像 Tomcat、Resin、Jetty 等等,它们会在...

红薯
今天
3
0
C++ std::thread

C++11提供了std::thread类来表示一个多线程对象。 1,首先介绍一下std::this_thread命名空间: (1)std::this_thread::get_id():返回当前线程id (2)std::this_thread::yield():用户接口...

yepanl
今天
3
0
Nignx缓存文件与动态文件自动均衡的配置

下面这段nginx的配置脚本的作用是,自动判断是否存在缓存文件,如果有优先输出缓存文件,不经过php,如果没有,则回到php去处理,同时生成缓存文件。 PHP框架是ThinkPHP,最后一个rewrite有关...

swingcoder
今天
2
0
20180920 usermod命令与用户密码管理

命令 usermod usermod 命令的选项和 useradd 差不多。 一个用户可以属于多个组,但是gid只有一个;除了gid,其他的组(groups)叫做扩展组。 usermod -u 1010 username # 更改用户idusermod ...

野雪球
今天
3
0
Java网络编程基础

1. 简单了解网络通信协议TCP/IP网络模型相关名词 应用层(HTTP,FTP,DNS等) 传输层(TCP,UDP) 网络层(IP,ICMP等) 链路层(驱动程序,接口等) 链路层:用于定义物理传输通道,通常是对...

江左煤郎
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部