Spring Boot配置Tomcat容器Jetty容器Undertow容器
Posted 丨Jack_Chen丨
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Spring Boot配置Tomcat容器Jetty容器Undertow容器相关的知识,希望对你有一定的参考价值。
@[TOC](Spring Boot配置Tomcat容器、Jetty容器、Undertow容器)
Tomcat、Jetty、Undertow
Tomcat概述
Jetty概述
Spring Boot配置Tomcat容器
添加依赖
Spring Boot配置Undertow容器
添加依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<!-- 移除掉默认支持的 Tomcat -->
<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>
启动日志
10:54:25.222 INFO 31904 --- [ restartedMain] o.s.b.d.a.OptionalLiveReloadServer : LiveReload server is running on port 35729
10:54:25.253 INFO 31904 --- [ restartedMain] io.undertow : starting server: Undertow - 2.1.5.Final
10:54:25.260 INFO 31904 --- [ restartedMain] org.xnio : XNIO version 3.8.0.Final
10:54:25.266 INFO 31904 --- [ restartedMain] org.xnio.nio : XNIO NIO Implementation Version 3.8.0.Final
10:54:25.311 INFO 31904 --- [ restartedMain] org.jboss.threads : JBoss Threads version 3.1.0.Final
10:54:25.357 INFO 31904 --- [ restartedMain] o.s.b.w.e.undertow.UndertowWebServer : Undertow started on port(s) 8888 (http)
10:54:25.367 INFO 31904 --- [ restartedMain] cn.ybzy.demo.Application : Started Application in 4.878 seconds (JVM running for 6.32)
配置
是否启动日志
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=-1
允许的最大 cookie 数量
server.undertow.max-cookies=100
允许的最大请求头数量
server.undertow.max-header-size=100
允许的最大请求行数量
server.undertow.max-request-lines=100
设置IO线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程
server.undertow.threads.io=4
阻塞任务线程池, 当执行类似servlet请求阻塞操作, undertow会从这个线程池中取得线程,它的值设置取决于系统的负载
server.undertow.threads.worker=20
每块buffer的空间大小,越小的空间被利用越充分,buffer会用于服务器连接的IO操作,类似netty的池化内存管理
server.undertow.buffer-size=1024
是否分配的直接内存
server.undertow.direct-buffers=true
是否启用SSL
server.undertow.https.enabled=false
# Spring Boot配置Jetty容器
>GitHub地址:`https://github.com/eclipse/jetty.project`
>Jetty也是Spring Boot默认集成的三大容器之一。
>Tomcat是SpringBoot默认的容器技术,同时SpringBoot也支持Jetty容器,而Jetty的性能和内存使用方面都优于Tomcat,弱于Undertow。
## 添加依赖
```xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<!-- 移除掉默认支持的 Tomcat -->
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<!-- 添加jetty容器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
启动日志
注意:这里启动时间更短是由于更换了性能更高的电脑,Jetty不做过多测试。
INFO 15196 --- [ restartedMain] o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService applicationTaskExecutor
INFO 15196 --- [ restartedMain] o.s.b.d.a.OptionalLiveReloadServer : LiveReload server is running on port 35729
INFO 15196 --- [ restartedMain] o.e.j.s.h.ContextHandler.application : Initializing Spring DispatcherServlet dispatcherServlet
INFO 15196 --- [ restartedMain] o.s.web.servlet.DispatcherServlet : Completed initialization in 3 ms
INFO 15196 --- [ restartedMain] o.e.jetty.server.AbstractConnector : Started ServerConnector@60c0e4a0HTTP/1.1, (http/1.1)0.0.0.0:8080
INFO 15196 --- [ restartedMain] o.s.b.web.embedded.jetty.JettyWebServer : Jetty started on port(s) 8080 (http/1.1) with context path /
INFO 15196 --- [ restartedMain] com.example.demo.DemoApplication : Started DemoApplication in 1.088 seconds (JVM running for 2.195)
Tomcat与Undertow容器性能对比
Undertow容器测试
总结
以上是关于Spring Boot配置Tomcat容器Jetty容器Undertow容器的主要内容,如果未能解决你的问题,请参考以下文章