使用Tomcat Native提升Tomcat IO效率的方法详解

 更新时间:2020年12月12日 08:54:47   作者:flydean程序那些事  
这篇文章主要介绍了使用Tomcat Native提升Tomcat IO效率的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

简介

IO有很多种,从最开始的Block IO,到nonblocking IO,再到IO多路复用和异步IO,一步一步的将IO的性能提升做到极致。

今天我们要介绍一下怎么使用Tomcat Native来提升Tomcat IO的效率。

Tomcat的连接方式

Tomcat中使用连接器来处理与外部客户端的通信。Connecter主要用来接受外部客户端的请求,并转交给处理引擎处理。

在Tomcat中有两种Connector。一种是 HTTP connector, 一种是AJP connector。

HTTP connector大家应该很好理解,它也是tomcat默认使用的连接器。

还有一个连接器叫做AJP,AJP主要是用来和web服务器进行通信用的,因为AJP协议的速度要比HTTP的快,所以AJP除了用来和其他webserver进行通信之外,还可以通过AJP来构建tomcat集群。

这两种方式都支持4中协议,分别是BIO,NIO,NIO2和APR。

#以下四种Connector实现都是直接处理来自客户端Http请求
org.apache.coyote.http11.Http11Protocol : 支持HTTP/1.1 协议的连接器。

org.apache.coyote.http11.Http11NioProtocol : 支持HTTP/1.1 协议+New IO的连接器。

org.apache.coyote.http11.Http11Nio2Protocol : 支持HTTP/1.1 协议+New IO2的连接器。

org.apache.coyote.http11.Http11AprProtocol : 使用APR(Apache portable runtime)技术的连接器,利用Native


#以下四种实现方法则是与web server打交道
org.apache.coyote.ajp.AjpProtocol:使用AJP协议的连接器,实现与web server(如Apache httpd)之间的通信

org.apache.coyote.ajp.AjpNioProtocol:SJP协议+ New IO

org.apache.coyote.ajp.AjpNio2Protocol:SJP协议+ New IO2

org.apache.coyote.ajp.AjpAprProtocol:AJP + APR

讲下他们的区别,BIO就是block IO是最最基础的IO方式, 我们通过这样来配置:

<Connector port=”8080” 
protocol=”HTTP/1.1”
 
maxThreads=”150” 
connectionTimeout=”20000” 
redirectPort=”8443” />

Tomcat7以下版本在默认情况下是以bio模式运行的。自Tomcat 8.5 版本开始,Tomcat就移除了对BIO的支持。

New IO是基于java.nio包及其子包的一种IO方式。能提供非阻塞IO方式,比传统的BIO拥有与更加高效的运行效率。

我们这样配置New IO:

<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8443" />

New IO和New IO2有什么区别呢?

New IO2是tomcat8中引入的IO方式,我们可以这样配置:

<Connector port="8080" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="20000"
redirectPort="8443" />

apr这种方式就高级了,这个是我们今天要讲解的tomcat native的主要作用。

APR和Tomcat Native

apr的全称是Apache Portable Runtime,它是一个高度可移植的库,它是Apache HTTP Server 2.x的核心。 APR有许多用途,包括访问高级IO功能(例如sendfile,epoll和OpenSSL),操作系统级别的功能(生成随机数,系统状态等)和本机进程处理(共享内存,NT管道和Unix套接字)。

Tomcat可以通过JNI的形式调用Apache HTTP服务器的核心动态链接库来处理文件读取或网络传输操作,从而大大地提高Tomcat对静态文件的处理性能。

通过使用APR我们可以获得如下的特性:

  • Non-blocking I/O和请求连接保持。
  • 支持OpenSSL和TLS/SSL。

Tomcat Native是一个库,通过这个库,Tomcat可以使用APR。

所以使用Tomcat Native的前提是需要安装好APR library,OpenSSL和JDK。

我们可以通过下面的方式来安装apr和openssl:

debian based linux系统:

apt-get install libapr1.0-dev libssl-dev

rpm based Linux 系统:

yum install apr-devel openssl-devel

在windows下面,tcnative是以一个dll的形式来提供的,我们直接下载使用就可以了。

但是在linux下面,因为平台不同,所以在linux下面tcnative是需要自行编译的。

一般来说我们可以在 bin/tomcat-native.tar.gz 找到tcnative的源码包。将其解压。

先运行configure命令:

./configure --with-apr=/usr/bin/apr-1-config \
  --with-java-home=/home/jfclere/JAVA/jdk1.7.0_80/ \
  --with-ssl=yes \
  --prefix=$CATALINA_HOME

再进行make操作:

make && make install

生成的lib文件将会被放入$CATALINA_HOME/lib中。

在tomcat中使用APR

安装好tcnative之后,我们就可以在tomcat中使用APR了。

先检查一下conf/server.xml中是否有下面的配置:

<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />

然后我们需要修改 $CATALINA_HOME/bin/setenv.sh 将tc-native 的lib文件添加到LD_LIBRARY_PATH中。

LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$CATALINA_HOME/lib
export LD_LIBRARY_PATH

最后添加APR的连接:

<Connector port="8080" protocol="org.apache.coyote.http11.Http11AprProtocol"
connectionTimeout="20000"
redirectPort="8443" />

运行即可。

从日志中,我们会发现下面的内容:

org.apache.catalina.core.AprLifecycleListener init

INFO: Loaded APR based Apache Tomcat Native library 1.x.y.

org.apache.catalina.core.AprLifecycleListener init

INFO: APR capabilities: IPv6 [true], sendfile [true], accept filters [false], random [true].

org.apache.coyote.http11.Http11AprProtocol init

说明APR安装完毕并且已经在被使用了。

到此这篇关于使用Tomcat Native提升Tomcat IO效率的方法详解的文章就介绍到这了,更多相关Tomcat Native提升Tomcat IO效率内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决“Unable to start embedded Tomcat“错误的完整指南

    解决“Unable to start embedded Tomcat“错误的完整

    在使用Spring Boot开发应用程序时,有时可能会遇到"Unable to start embedded Tomcat"的错误,这可能是由多种原因引起的,本文将详细介绍这个错误的常见原因以及解决方法,帮助你快速解决问题并顺利启动应用程序
    2023-10-10
  • Linux下Tomcat8.0.44配置使用Apr的方法

    Linux下Tomcat8.0.44配置使用Apr的方法

    下面小编就为大家带来一篇Linux下Tomcat8.0.44配置使用Apr的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • 解决Tomcat重新部署后图片等资源被自动删除的问题

    解决Tomcat重新部署后图片等资源被自动删除的问题

    这篇文章主要介绍了解决Tomcat重新部署后图片等资源被自动删除的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • 分析Tomcat的工作原理

    分析Tomcat的工作原理

    这篇文章主要介绍了Tomcat的工作原理是怎样的,帮助大家清楚 Tomcat 的工作原理和处理请求流程和分析,感兴趣的朋友可以了解下
    2020-09-09
  • Tomcat配置IPV6的实现步骤

    Tomcat配置IPV6的实现步骤

    本文主要介绍了Tomcat配置IPV6的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • Tomcat 是如何管理Session的方法示例

    Tomcat 是如何管理Session的方法示例

    这篇文章主要介绍了Tomcat 是如何管理Session的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • 关于Keytool配置 Tomcat的HTTPS双向认证的问题

    关于Keytool配置 Tomcat的HTTPS双向认证的问题

    Keytool是一个Java数据证书的管理工具, Keytool将密钥(key)和证书(certificates)存在一个称为keystore的文件中,这篇文章主要介绍了Keytool配置 Tomcat的HTTPS双向认证问题,需要的朋友可以参考下
    2022-06-06
  • tomcat虚拟路径的配置方法汇总

    tomcat虚拟路径的配置方法汇总

    本文给大家简单汇总介绍了tomcat虚拟路径的配置方法,十分的简单实用,有需要的小伙伴可以参考下。
    2016-01-01
  • tomcat性能优化之如何搭建Apr模块

    tomcat性能优化之如何搭建Apr模块

    这篇文章主要介绍了tomcat性能优化之如何搭建Apr模块,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-07-07
  • Tomcat 中如何给 web 项目配置虚拟目录的方法

    Tomcat 中如何给 web 项目配置虚拟目录的方法

    本篇文章主要介绍了Tomcat 中如何给 web 项目配置虚拟目录的方法,具有一定的参考价值,有兴趣的可以了解一下
    2017-08-08

最新评论