最近开发项目,顺丰那边人要求把SpringBoot中的Tomcat服务器替换为Undertow容器,我也是第一次听说这个容器,平时都是Tomcat用的多,既然听说了,那就要研究下,不然岂不是很可惜?毕竟既然说替换,那其必然有相对Tomcat在某些方面具备更大的优势。哈哈,好了,切入正题,我们都知道Spring Boot内嵌容器默认启动的都是Tomcat,但是其实Spring Boot内嵌容器除了支持Tomcat还有Jetty和Undertow。

1、Undertow是什么?

Undertow 是红帽公司开发的一款基于 NIO 的高性能 Web 嵌入式服务器,其官网为:点击访问官网
官网的英文翻译后描述如下(机译,别太较真~):

Undertow 是一个用 Java 编写的灵活的高性能 Web 服务器,提供基于 NIO 的阻塞和非阻塞 API。

Undertow 具有基于组合的架构,允许您通过组合小型单一用途处理程序来构建 Web 服务器。这使您可以灵活地在完整的 Java EE servlet 4.0 容器或低级非阻塞处理程序之间进行选择。

Undertow 被设计为完全可嵌入的,具有易于使用的流畅构建器 API。Undertow 的生命周期完全由嵌入应用程序控制

2、为什么选择Undertow?

我们先说下其特点:

  • 轻量级:它是一个 Web 服务器,但不像传统的 Web 服务器有容器概念,它由两个核心 Jar 包组成,加载一个 Web 应用可以小于 10MB 内存
  • Servlet3.1 支持:它提供了对 Servlet3.1 的支持
  • WebSocket 支持:对 Web Socket 完全支持,用以满足 Web 应用巨大数量的客户端
  • 嵌套性:它不需要容器,只需通过 API 即可快速搭建 Web 服务器

官网的翻译如下:

HTTP/2 支持
Undertow 支持开箱即用的 HTTP/2,无需覆盖引导类路径。
HTTP 升级支持
支持 HTTP 升级,允许多个协议通过 HTTP 端口复用。
网络套接字支持
Undertow 提供对 Web Sockets 的全面支持,包括 JSR-356 支持。
小服务程序 4.0
Undertow 提供对 Servlet 4.0 的支持,包括对嵌入式 servlet 的支持。还可以在同一部署中混合使用 Servlet 和本机 undertow 非阻塞处理程序。
可嵌入
Undertow 可以嵌入到应用程序中,也可以通过几行代码独立运行。
灵活的
Undertow 服务器是通过将处理程序链接在一起来配置的。可以根据需要添加尽可能多或尽可能少的功能,因此您无需为未使用的功能付费。

总结起来就是一个字:好!哈哈~

3、SpringBoot怎么使用Undertow?

1)添加依赖

首先我们要在pom.xml中添加Undertow的依赖,并且要移除对Tomcat的默认依赖,具体如下:

 <!--移除Tomcat依赖--> <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> <!--引入undertow--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-undertow</artifactId> </dependency> 

2)配置

application.yml添加对undertow配置如下(与原来使用Tomcat时配置无太大差别 , 将tomcat字段改为undertow即可):

 server: port: 8080 #undertow配置 undertow: # 设置IO线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程 # 不要设置过大,如果过大,启动项目会报错:打开文件数过多 io-threads: 32 # 阻塞任务线程池, 当执行类似servlet请求阻塞IO操作, undertow会从这个线程池中取得线程 # 它的值设置取决于系统线程执行任务的阻塞系数,默认值是IO线程数*8 worker-threads: 2000 # 以下的配置会影响buffer,这些buffer会用于服务器连接的IO操作,有点类似netty的池化内存管理 # 每块buffer的空间大小,越小的空间被利用越充分,不要设置太大,以免影响其他应用,合适即可 buffer-size: 1024 # 是否分配的直接内存(NIO直接分配的堆外内存) direct-buffers: true 

更多的配置,可自行去研究。

3)启动

正常去启动Application,打印日志发现有启动undertow:

4)访问

正常去访问8080端口,效果和tomcat还是一样,整合替换完毕,就是这么easy~。