1. Undertow 简介
Undertow 是一个采用 Java 开发的灵活的高性能 Web 服务器,提供包括阻塞和基于 NIO 的非堵塞机制。Undertow 是红帽公司的开源产品,是 Wildfly 默认的 Web 服务器。Undertow 提供一个基础的架构用来构建 Web 服务器,这是一个完全为嵌入式设计的项目,提供易用的构建器 API,完全向下兼容 Java EE Servlet 3.1 和低级非堵塞的处理器。
2. Undertow特点
3. 替换默认的Tomcat
Spring boot 默认使用 Tomcat 内嵌容器 。依赖于 spring-boot-starter-web 。我们只需要排除 Tomcat 依赖。引用Undertow 就可以了,maven 配置如下:
org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-tomcat org.springframework.boot spring-boot-starter-undertow
4. 自定义配置Undertow
其实到第三步已经可以愉快地玩耍了。你可以立即在 https://felord.cn 找到更多教程来学习Spring Boot。当然你也可以再折腾一番,通过在Spring Boot 配置文件application.yml中配置 ServerProperties 和ServerProperties.Undertow 的相关属性。 总结了一下比较陌生的ServerProperties.Undertow 的属性:
# 设置IO线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程 # 不要设置过大,如果过大,启动项目会报错:打开文件数过多 server: undertow: io-threads: 16 # 阻塞任务线程池, 当执行类似servlet请求阻塞IO操作, undertow会从这个线程池中取得线程 # 它的值设置取决于系统线程执行任务的阻塞系数,默认值是IO线程数*8 worker-threads: 256 # 以下的配置会影响buffer,这些buffer会用于服务器连接的IO操作,有点类似netty的池化内存管理 # 每块buffer的空间大小,越小的空间被利用越充分,不要设置太大,以免影响其他应用,合适即可 buffer-size: 1024 # 每个区分配的buffer数量 , 所以pool的大小是buffer-size * buffers-per-region buffers-per-region: 1024 # 是否分配的直接内存(NIO直接分配的堆外内存) direct-buffers: true
5. 总结
今天我们演示了如何用性能优良的 Undertow 来作为Spring Boot 的 Servlet Web 容器。其实在并发量不大的情况下 Undertow、和其它两款 Servlet Web 容器 Jetty 、Tomcat 的差距并不是很大。 Undertow 的优势是高并发下的吞吐量。你可以根据自己的实际需要来选择。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。