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, ...
随机推荐
- SQLAllocStmt与SQLFreeStmt
1.申请语句句柄 SQLAllocStmt函数为应用程序分配语句句柄,其格式为:RETCODE SQLAllocStmt(HDBC hdbc, HSTMT FAR * phstmt) 其中, hdbc ...
- django用户认证系统——注册3
用户注册就是创建用户对象,将用户的个人信息保存到数据库里.回顾一下 Django 的 MVT 经典开发流程,对用户注册功能来说,首先创建用户模型(M),这一步我们已经完成了.编写注册视图函数(V),并 ...
- 66、多种多样的App主界面Tab(1)------ ViewPager实现Tab
<?xml version="1.0" encoding="utf-8"?> <!-- bottom.xml --> <Linea ...
- 《程序员级别鉴定书》 ----中级.NET开发者
面向接口.面向对象和面向方面编程区别 面向接口编程 是面向对象编程体系中的思想精髓之一 (博客园文章链接面向接口编程详解(一)——思想基础) 面向接口编程 接口是一组规则集合 面向对象编程 对具有相同 ...
- python中获取字典的key列表和value列表
# -*- coding: utf-8 -*- # 定义一个字典 dic = {'剧情': 11, '犯罪': 10, '动作': 8, '爱情': 3, '喜剧': 2, '冒险': 2, '悬疑' ...
- 8.javascript获取表单中两个数字,并判断大小
获取表单数据的方式: 1.表单注意些id 2.使用document.getElementById("num").value 获取值 3.一定要注意现在得到是string类型,可以用 ...
- Howto: Performance Benchmarks a Webserver
Howto: Performance Benchmarks a Webserver last updated June 9, 2006 in CategoriesApache, FreeBSD, Ho ...
- 第12章—整合Redis
spring boot 系列学习记录:http://www.cnblogs.com/jinxiaohang/p/8111057.html 码云源码地址:https://gitee.com/jinxia ...
- jQuery实现图片预览
摘自:http://www.cnblogs.com/leejersey/p/3660202.html JS代码: /* *名称:图片上传本地预览插件 v1.1 *作者:周祥 *时间:2013年11月2 ...
- Django限制请求method
1.常用的请求method 1.1 GET请求: GET请求一般用来向服务器索取数据,但不会向服务器提交数据,不会对服务器的状态进行更改.比如向服务器获取某篇文章的详情. 1.2 POST请求: PO ...