• 使用 Undertow 来替代Tomcat


    undertow

    概述 :

    Undertow 是红帽公司开发的一款基于 NIO 的高性能 Web 嵌入式服务器

    特点 :

    轻量级:它是一个 Web 服务器,但不像传统的 Web 服务器有容器概念,它由两个核心 Jar 包组成,加载一个 Web 应用可以小于 10MB 内存

    Servlet3.1 支持:它提供了对 Servlet3.1 的支持

    WebSocket 支持:对 Web Socket 完全支持,用以满足 Web 应用巨大数量的客户端

    嵌套性:它不需要容器,只需通过 API 即可快速搭建 Web 服务器

    Spring Boot项目中的引入方式 :

    Spring Boot 内嵌 Jetty , Tomcat , Undertow , 默认是Tomcat

    pom.xml配置

    添加如下依赖

     <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>
                <version>1.5.10.RELEASE</version>
            </dependency>

    如果你启动报错的话,在添加下面的依赖

     <dependency>
                <groupId>io.undertow</groupId>
                <artifactId>undertow-core</artifactId>
                <version>2.0.16.Final</version>
            </dependency>
            <!-- https://mvnrepository.com/artifact/io.undertow/undertow-servlet -->
            <dependency>
                <groupId>io.undertow</groupId>
                <artifactId>undertow-servlet</artifactId>
                <version>2.0.16.Final</version>
            </dependency>
            <!-- https://mvnrepository.com/artifact/io.undertow/undertow-websockets-jsr -->
            <dependency>
                <groupId>io.undertow</groupId>
                <artifactId>undertow-websockets-jsr</artifactId>
                <version>2.0.16.Final</version>
            </dependency>

     application.yml

    # 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线程数, 它主要执行非阻塞的任务,它们会负责多个连接, 默认设置每个CPU核心一个线程
    server.undertow.io-threads=4
    # 阻塞任务线程池, 当执行类似servlet请求阻塞操作, undertow会从这个线程池中取得线程,它的值设置取决于系统的负载
    server.undertow.worker-threads=20
    # 以下的配置会影响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

    Undertow特点

    • 高性能 在多款同类产品的压测中,在高并发情况下表现出色。
    • Servlet4.0 支持 它提供了对 Servlet4.0 的支持。
    • Web Socket 完全支持,包括JSR-356,用以满足 Web 应用巨大数量的客户端。
    • 内嵌式 它不需要容器,只需通过 API 即可快速搭建 Web 服务器。
    • 灵活性 交由链式Handler配置和处理请求,可以最小化按需加载模块,无须加载多余功能。
    • 轻量级 它是一个 内嵌Web 服务器, 由两个核心 Jar 包组成

    总结

    其实在并发量不大的情况下 Undertow、和其它两款 Servlet Web 容器 JettyTomcat 的差距并不是很大。 Undertow 的优势是高并发下的吞吐量。你可以根据自己的实际需要来选择。

    QPS测试结果对比:

    Tomcat

    Undertow

    内存使用对比:

    Tomcat

    Undertow

    通过测试发现,在高并发系统中,Tomcat相对来说比较弱。在相同的机器配置下,模拟相等的请求数,Undertow在性能和内存使用方面都是最优的。并且Undertow新版本默认使用持久连接,这将会进一步提高它的并发吞吐能力。所以,如果是高并发的业务系统,Undertow是最佳选择。

  • 相关阅读:
    python调用c++动态库报错
    Python自动化测试常用库整理
    Linux kswapd0 进程CPU占用过高快速处理方法
    Linux安装jdk8及环境变量配置
    免费的网站安全检查和恶意软件扫描程序
    【Java】对象的创建、初始化和使用
    【Java】数组的创建、遍历和复制
    【Java】Java 语言中流程控制语句(分支语句、循环语句、转移语句)的一些新特性
    【Java】Java 语言中操作符的一些新特性
    【Java】常量与变量(局部变量、成员变量)
  • 原文地址:https://www.cnblogs.com/dalianpai/p/12595196.html
Copyright © 2020-2023  润新知