一、Undertow简介
Undertow 是红帽公司开发的一款基于 NIO 的高性能 Web 嵌入式服务器,
Untertow 的特点:
- 轻量级:它是一个 Web 服务器,但不像传统的 Web 服务器有容器概念,它由两个核心 Jar 包组成,加载一个 Web 应用可以小于 10MB 内存;
- Servlet3.1 支持:它提供了对 Servlet3.1 的支持;
- WebSocket 支持:对 Web Socket 完全支持,用以满足 Web 应用巨大数量的客户端;
- 嵌套性:它不需要容器,只需通过 API 即可快速搭建 Web 服务器;
- 默认情况下 Spring Cloud 使用 Tomcat 作为内嵌 Servlet 容器,可启动一个 Tomcat 的 Spring Boot 程序与一个 Undertow 的 Spring Boot 程序,通过 VisualVM 工具进行比较,可看到 Undertow 性能优于 Tomcat;
二、Maven依赖
<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>
三、配置
# 设置IO线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程
# 不要设置过大,如果过大,启动项目会报错:打开文件数过多
server.undertow.io-threads=16
# 阻塞任务线程池, 当执行类似servlet请求阻塞IO操作, undertow会从这个线程池中取得线程
# 它的值设置取决于系统线程执行任务的阻塞系数,默认值是IO线程数*8
server.undertow.worker-threads=256
# 以下的配置会影响buffer,这些buffer会用于服务器连接的IO操作,有点类似netty的池化内存管理
# 每块buffer的空间大小,越小的空间被利用越充分,不要设置太大,以免影响其他应用,合适即可
server.undertow.buffer-size=1024
# HTTP内容的最大大小(以字节为单位)
server.undertow.max-http-post-size=1024
# 是否分配的直接内存(NIO直接分配的堆外内存)
四、常用配置列表
参数 | 描述 |
---|---|
server.undertow.accesslog.dir | 访问日志目录 |
server.undertow.accesslog.enabled = false | 启用访问日志 |
server.undertow.accesslog.pattern = common | 访问日志的格式模式 |
server.undertow.accesslog.prefix = access_log. | 日志文件名前缀 |
server.undertow.accesslog.rotate = true | 启用访问日志轮换 |
server.undertow.accesslog.suffix = log | 日志文件名后缀 |
server.undertow.buffer-size | 每个缓冲区的大小(以字节为单位) |
server.undertow.direct-buffers | 在Java堆之外分配缓冲区 |
server.undertow.io-threads | 为工作者创建的I / O线程数 |
server.undertow.max-http-post-size = 0 | HTTP帖子内容的最大大小(以字节为单位) |
server.undertow.worker-threads | 工作线程数 |
网友评论