89_SpringBoot2.x系列教程89--SpringBoot中整合Undertow

作者:一一哥

  • ​89_SpringBoot2.x系列教程89--SpringBoot中整合Undertow​
  • ​一. Undertow简介​
  • ​​1. Untertow 概念​​
  • ​​2. Untertow 特点​​
  • ​​二. Undertow用法​​
  • ​​三. Undertow配置详解​​

一. Undertow简介

1. Untertow 概念

Undertow 是红帽公司开发的一款基于 NIO 的高性能 Web 嵌入式服务器,支持Servlet,JSP,文件服务器,代理服务器,安全认证等特性,功能基本与Tomcat相同。

Undertow的主要运用场景是在IO密集型的系统中,并且认为多核机器是一个比较容易满足的点,Undertow初始化认为一个应用的阻塞系数在0.8~0.9之间,所以阻塞线程数直接乘了个8。当然,如果对应用较精确的估测阻塞系数,可以配置上去。

2. Untertow 特点

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

我们知道在Spring Boot中,支持的内嵌容器有Tomcat、Jetty、Undertow,而默认情况下 Spring Boot是使用 Tomcat 作为内嵌的 Servlet容器的。

当我们启动一个 Tomcat 的 Spring Boot 程序与一个 Undertow 的 Spring Boot 程序时,通过 VisualVM 工具进行比较,会发现 Undertow 性能优于 Tomcat。

二. Undertow用法

我们只需要在pom文件中,移除SpringBoot自带的tomcat容器,然后添加Undertow依赖就可以了。

<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-undertow</artifactId>
</dependency>

三. Undertow配置详解

# Undertow 日志存放目录
server.undertow.accesslog.dir=xxx
# 是否启动日志
server.undertow.accesslog.enabled=false
# 日志格式
server.undertow.accesslog.pattern=common
# 日志文件名前缀
server.undertow.accesslog.prefix=access_log
# 日志文件名后缀
server.undertow.accesslog.suffix=log
# HTTP POST请求最大的大小
server.undertow.max-http-post-size=0
# 设置IO线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程。
#该值不要设置过大,如果过大,启动项目会报错:打开文件数过多
server.undertow.io-threads=16
# 阻塞任务线程池, 当执行类似servlet请求阻塞操作, undertow会从这个线程池中取得线程,它的值设置取决于系统线程执行任务的阻塞系数,默认值是IO线程数*8
server.undertow.worker-threads=128
# 以下的配置会影响buffer,这些buffer会用于服务器连接的IO操作,有点类似netty的池化内存管理
# 每块buffer的空间大小,越小的空间被利用越充分,不要设置太大,以免影响其他应用,合适即可
server.undertow.buffer-size=1024
# 每个区分配的buffer数量 , 所以pool的大小是buffer-size * buffers-per-region
server.undertow.buffers-per-region=1024
# 是否分配的直接内存
server.undertow.direct-buffers=true