Spring Boot - Undertow容器啟動

Undertow

  • Undertow 是紅帽公司開發(fā)的一款基于 NIO 的高性能 Web 嵌入式服務器
  • Untertow 的特點:
    輕量級:它是一個 Web 服務器,但不像傳統(tǒng)的 Web 服務器有容器概念,它由兩個核心 Jar 包組成,加載一個 Web 應 用可以小于 10MB 內(nèi)存
    Servlet3.1 支持:它提供了對 Servlet3.1 的支持
    WebSocket 支持:對 Web Socket 完全支持,用以滿足 Web 應用巨大數(shù)量的客戶端
    嵌套性:它不需要容器,只需通過 API 即可快速搭建 Web 服務器
  • 默認情況下 Spring Cloud 使用 Tomcat 作為內(nèi)嵌 Servlet 容器,可啟動一個 Tomcat 的 Spring Boot 程序與一個 Undertow 的 Spring Boot 程序,通過 VisualVM 工具進行比較,可看到 Undertow 性能優(yōu)于 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>

支持 HTTP2

// 在@Configuration的類中添加@bean
@Bean
UndertowEmbeddedServletContainerFactory embeddedServletContainerFactory() {
    
    UndertowEmbeddedServletContainerFactory factory = new UndertowEmbeddedServletContainerFactory();
    
    // 這里也可以做其他配置
    factory.addBuilderCustomizers(builder -> builder.setServerOption(UndertowOptions.ENABLE_HTTP2, true));
    
    return factory;
}

配置 Undertow

    # Undertow 日志存放目錄
    server.undertow.accesslog.dir
    # 是否啟動日志
    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線程數(shù), 它主要執(zhí)行非阻塞的任務,它們會負責多個連接, 默認設置每個CPU核心一個線程
    server.undertow.io-threads=4
    # 阻塞任務線程池, 當執(zhí)行類似servlet請求阻塞操作, undertow會從這個線程池中取得線程,它的值設置取決于系統(tǒng)的負載
    server.undertow.worker-threads=20
    # 以下的配置會影響buffer,這些buffer會用于服務器連接的IO操作,有點類似netty的池化內(nèi)存管理
    # 每塊buffer的空間大小,越小的空間被利用越充分
    server.undertow.buffer-size=1024
    # 每個區(qū)分配的buffer數(shù)量 , 所以pool的大小是buffer-size * buffers-per-region
    server.undertow.buffers-per-region=1024
    # 是否分配的直接內(nèi)存
    server.undertow.direct-buffers=true

個人博客
騰訊云社區(qū)
掘金
CSDN
OSCHINA
公眾號:

wx.jpg

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容