吊打tomcat的高性能web服务器
Posted 面包聊技术
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了吊打tomcat的高性能web服务器相关的知识,希望对你有一定的参考价值。
一,undertow介绍
1,undertow简介:
2,undertow特点:
undertow在高并发业务场景中,性能优于tomcat
1,高性能,在多款同类产品的压测对比中,高并发情况下表现出色。
2,Servlet4.0支持,它提供了对Servlet4.0的支持。
3,Web Socket完全支持,包含JSR-356,用以满足Web应用巨大数量的客户端。
4,内嵌式,它不需要容器,只需要通过api即可快速搭建Web服务器。
5,灵活性,交由链式Handler配置和处理请求,可以最小化按需加载模块,无须加载多余功能。
6,轻量级,它是一个内嵌Web服务器,由两个核心jar包组成。
3,springboot集成的web服务器
2.2.13.RELEASE springboot版本默认支持的三种Servlet容器版本如下
2.2.13.RELEASE springboot版本(官网提供的) |
|
Web服务器 |
集成版本 |
Undertow |
2.0.33.Final |
tomcat |
9.0.41 |
jetty |
4.1.17 |
二,实验验证
实验准备材料如下:
1,springboot版本
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.2.RELEASE</version>
</parent>
2,测试类的controller
@RequestMapping("/reflect")
@ResponseBody
public void reflect() {
Object object = springReflectionUtil.springInvokeMethod("reflectService", "handleUser");
if (object instanceof User) {
User invoke = (User)object;
}
}
3,springboot默认就内嵌了tomcat
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
4,项目整合undertow
在pom文件中引入以下依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-undertow</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
5,项目整合jetty
在pom文件中引入以下依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
6,jvm配置
-server
-Xms4096m
-Xmx4096m
-XX:+UseG1GC
7,用jmeter压测
tomcat,jetty,undertow分别模拟10万请求,查看各自的吞吐量数据
场景一:100个线程 循环1000次请求测试接口,模拟10万请求
场景二:1000个线程 循环100次请求测试接口,模拟10万请求
8,实验结果
tomcat
data:image/s3,"s3://crabby-images/4285d/4285dabda8f94c68941184b328944e77a1310760" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/2601e/2601e2b2ba91c35aeda0b82ca0e40642bace0f6f" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/c9db9/c9db95ecbbc2f14b38ad0e89bfd8950b99d658e9" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/3fead/3fead5eb29298dd4f519460e019fef27b9bddd24" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/9019e/9019e970186960d648dbb40c9ea5571e5ec1a7f7" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/a8475/a8475ad0dad85d8ede051e4be9693742503edeb8" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/cab79/cab799afeeb237521a44bc93cd0928c5ffe04c8c" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/e8405/e840539978fb9d3cd11d8176e87806e580dfaac7" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/8c008/8c0088c9a2341796d2a0a79d534234ecc654fe35" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/8ebd1/8ebd151055bc7701fb30e62458f40462c0e3265b" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/746ad/746ad571c103a1853dd8f561c1c0002b8352de76" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/4df2e/4df2e8735270ca267e212097121ceeb169d6a06f" alt="吊打tomcat的高性能web服务器"
undertow
data:image/s3,"s3://crabby-images/c7e44/c7e44a7250018b962c0f011bd9fc202e2252c0c0" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/caddd/cadddbed69f41f98aa7fa0969242921970baee97" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/88953/889530e846dfb77fb7218851c33b9ef5e92a8a86" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/7e448/7e4480098c521efbd20bd3541480ebb1eeb53df4" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/d5de1/d5de1a81cdbef616f7dcb1456391b142e45f3924" alt="吊打tomcat的高性能web服务器"
data:image/s3,"s3://crabby-images/4562e/4562e213a9734b10bf43b2c9de345b7502eeab91" alt="吊打tomcat的高性能web服务器"
通过压测结果图统计如下
|
||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
||||
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
三,实验结论
100个线程循环1000次,都用默认配置,没有调配置参数情况下
tomcat的吞吐量平均是每秒1369.2,jetty的吞吐量平均是1394.5,undertow的吞吐量平均是每秒1540.3
1000个线程循环100次,都用默认配置,没有调配置参数情况下
tomcat的吞吐量平均是每秒1136.0,jetty的吞吐量是1211.6,undertow的吞吐量是每秒1428.7
可以看出,默认配置情况下
undertow的吞吐量领先于jetty和tomcat,表现更优异
undertow>jetty>tomcat
最后说一句
data:image/s3,"s3://crabby-images/c976b/c976bd4ac12761fa4aa91c6fdcf3547b41aac542" alt="吊打tomcat的高性能web服务器"
以上是关于吊打tomcat的高性能web服务器的主要内容,如果未能解决你的问题,请参考以下文章
Tomcat结合ApacheNginx实现高性能的web服务器
在Tomcat的安装目录下conf目录下的server.xml文件中增加一个xml代码片段,该代码片段中每个属性的含义与用途