SpringBoot服务器压测对比(jetty、tomcat、undertow)
1、本次对比基础环境信息如下:
springboot版本1.5.10
centos虚机4c6G,版本7.4
centos实机2u16c40G,版本7.4,虚机运行在实机上
ab版本2.3
jprofiler版本9.1.1
2、压测接口说明
天花板:指的是一个空接口,没有任何实现,直接返回,如
@RequestMapping(value = "/test", method = RequestMethod.GET)
public void test() {
}
服务接口:指的是具有一定业务代码的接口,连接数据库/Redis然后返回json数据
异步接口:指的是开启了http异步
3、压测过程
JETTY
先以Jetty开始,这里通过优化参数来不断摸底。以下是参数说明:
jettyMin:最小连接数
jettyMax:最大连接数
mvcCore:线程池core数量
mvcMax:线程池最大量
mvcQueue:线程池队列大小
大致结果如下:
JETTY天花板(无异步) | ||||
jettyMin | 50 | 100 | 200 | 300 |
jettyMax | 600 | 600 | 600 | 600 |
mvcCore | 50 | 50 | 50 | 50 |
mvcMax | 200 | 200 | 200 | 200 |
mvcQueue | 100 | 100 | 100 | 100 |
结果 | 2090 | 2116 | 2374 | 2100 |
JETTY天花板(无异步) | |||
jettyMax | 400 | 600 | 800 |
jettyMin | 200 | 200 | 200 |
mvcCore | 50 | 50 | 50 |
mvcMax | 200 | 200 | 200 |
mvcQueue | 100 | 100 | 100 |
结果 | 1655 | 2170 | 2000 |
JETTY天花板(异步) | |||
jettyMax | 600 | 600 | 600 |
jettyMin | 200 | 200 | 200 |
mvcCore | 50 | 100 | 200 |
mvcMax | 200 | 200 | 200 |
mvcQueue | 100 | 100 | 100 |
结果 | 1500 | 1600 | 1450 |
JETTY天花板(异步) | |||
jettyMax | 600 | 600 | 600 |
jettyMin | 200 | 200 | 200 |
mvcCore | 100 | 100 | 100 |
mvcMax | 200 | 400 | 600 |
mvcQueue | 100 | 100 | 100 |
结果 | 1600 | 1700 | 1550 |
JETTY天花板(异步) | |||
jettyMax | 600 | 600 | 600 |
jettyMin | 200 | 200 | 200 |
mvcCore | 100 | 100 | 100 |
mvcMax | 400 | 400 | 400 |
mvcQueue | 100 | 200 | 300 |
结果 | 1600 | 1700 | 1600 |
以下是通过工具预估最佳线程数,然后修改优化参数的结果:
JETTY天花板(无异步) | |||
jettyMax | 600 | 52 | |
jettyMin | 200 | 52 | |
mvcCore | 52 | 52 | |
mvcMax | 52 | 52 | |
mvcQueue | 199 | 199 | |
结果 | 1520 | 1600 |
JETTY业务接口(异步) | |||
jettyMax | 600 | ||
jettyMin | 200 | ||
mvcCore | 52 | ||
mvcMax | 52 | ||
mvcQueue | 199 | ||
结果 | 1719 |
JETTY业务接口(无异步) | |||
jettyMax | 600 | ||
jettyMin | 200 | ||
mvcCore | 52 | ||
mvcMax | 52 | ||
mvcQueue | 199 | ||
结果 | 2000 |
通过以上结果发现一个问题,开启异步HTTP后压测的结果均不如不开启HTTP异步的结果。
TOMCAT
通过切换成tomcat再按照以上过程压测,发现HTTP和tomcat才是天生一对,组合压测下的结果和Jetty不开启异步的结果差不多。这里不再重复贴出数据表格。
UNDERTOW
通过Jetty和tomcat的压测结果发现,HTTP异步并不一定会提升程序性能,只有在特定的条件下才会起到正面的效果,如应用服务器为非NIO时。而undertow和jetty一样是NIO,所以这里不再对比异步非异步,直接只测非异步。优化参数只有两个:
ioThreads:cpu核数
workerThreads:工作线程数(可以通过工具预估出来)
以下是数据。
UNDERTOW业务接口(无异步) | |||
ioThreads | 4 | ||
workerThreads | 52 | ||
结果 | 2200 |
UNDERTOW天花板(无异步) | |||
ioThreads | 4 | ||
workerThreads | 52 | ||
结果 | 3100 |
4、jprofiler图标对比
jetty
tomcat
UNDERTOW
5、附最佳线程数预估工具
GITHUB地址https://github.com/sunshanpeng/dark_magic 原文博客:http://ifeve.com/how-to-calculate-threadpool-size/
Undertow使用&优化:https://www.jianshu.com/p/e625b8aa0e80
原文链接:https://my.oschina.net/shyloveliyi/blog/2980440
SpringBoot服务器压测对比(jetty、tomcat、undertow)的更多相关文章
- web服务器压测工具siege、ab
web服务器压测工具也挺多,这里只介绍我用过的这两种--siege(for linux).ab(for windows). 一.siege 1.简介: Siege是一款开源的压力测试工具,设计用于评估 ...
- (转)一次压测对nginx/tomcat配置的调整
原文地址:还在寻找.... 一个web系统,前端使用nginx做为反向代理,处理https,并将请求转发给后端的tomcat服务. 压力测试工具选择了jmeter. 首先简单介绍一下jmeter. 它 ...
- 压力测试(六)-阿里云Linux服务器压测接口实战
1.SpringBoot 接口打包,并用jar包方式部署 简介:用jar包方式在控制台进行启动 打包 mvn package && java -jar target/gs-spring ...
- Jmeter非GUI界面对阿里云服务器压测
一.Jmeter非GUI界面 参数讲解 讲解:非GUI界面,压测参数讲解 -h 帮助 -n 非GUI模式 -t 指定要运行的 JMe ...
- JMeter性能测试9:阿里云服务器压测
第一步准备好jmeter脚本 第二步 将本地的jmeter脚本上传到阿里云进行验证 检验阿里云的jmeter是否能正常运行 将本地的脚本上传到阿里云使用xshell进入到该目录下 使用命令运行刚才上传 ...
- 利器: 用Siege做Web服务器压测
用「Web压测」关键词检索,能找到好多进行压测的工具,比如ab.Http_load.Webbench.Siege这些,不过今天并不是要对这些工具做对比,毕竟我们只是想得到一个结果.本文主要介绍Sieg ...
- nginx、php-fpm、swoole HTTP/TCP压测对比
本次测试是在win7下docker环境中进行压测,共创建一个nginx容器.一个php-fpm容器和一个swoole容器,客户端请求nginx服务器,nginx接收用户访问请求并转发给php-fpm, ...
- Linux服务器压测/拷机软件收集
最近公司采购了一批服务器,于是收集了一些拷机软件来压测服务器硬件性能.硬件的稳定相对来说比较重要,7x24小时无间断运行,主要看三个硬件:CPU.内存.硬盘. 下面是收集的一些教程,可能网址已经失效了 ...
- CoolHash数据库引擎压测对比报告
Coolhash 当前性能指标:读写吞吐量超过百万,千万级别查询1秒完成,连续48小时打满CPU强压力运行稳定.redis官方公布读写性能在10万 tps,leveldb官方公布写性能在40万tps, ...
随机推荐
- 微信 Mustache
最近微信小程序非常火,对于前端开发的程序员是个利好的消息,这里主要记录下微信小程序 Mustache语法. 小程序开发的wxml里,用到了Mustache语法.所以,非常有必要把Mustache研究 ...
- iOS -转载-字符串是否为空判断方法
- (BOOL)blankString{ if (![self isKindOfClass:[NSString class]] ){ return YES; } if ([self isEqual:[ ...
- Android无线测试之—UiAutomator UiCollection API介绍
UiCollection类介绍 一.UiCollection类说明 1)UiCollection类是UiObject类的子类,即UiObject类的所有方法都被UiCollection继承下来了,都可 ...
- PAT 1016 Phone Bills(模拟)
1016. Phone Bills (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A long-di ...
- k8s更新Pod镜像
实际使用k8s中,如果使用RC启动pod可以直接使用滚动更新进行pod版本的升级,但是我们使用的情况是在pod里面启动有状态的mysql服务,没有和RC进行关联,这样更新的时候只能通过 更新pod的配 ...
- php 解决上传中文文件名时出现乱码的问题
有时候上传文件是中文的文件名会出现乱码, 可以在移动文件时使用icov('utf-8','gb2312',filename)转换 代码: <?php //header('Content-type ...
- JS给html控件赋值
<html> <head> <title> JS给html控件赋值 </title> <script language="javascr ...
- 【转】Spring AOP 实现原理与 CGLIB 应用
AOP(Aspect Orient Programming),作为面向对象编程的一种补充,广泛应用于处理一些具有横切性质的系统级服务,如事务管理.安全检查.缓存.对象池管理等.AOP 实现的关键就在于 ...
- Python获取指定路径下所有文件的绝对路径
需求 给出制定目录(路径),获取该目录下所有文件的绝对路径: 实现 方式一: import os def get_file_path_by_name(file_dir): ''' 获取指定路径下所有文 ...
- android studio 中类似VS的代码折叠功能Region
1. 打开android studio 2. 选择要折叠的代码 3. 按Ctrl + Alt + T 选择 “region .. end region comments” Group selectio ...