tomcat启动nio,apr详解以及配置
tomcat启动nio,apr详解以及配置
前言
在正文开始之前,我们先在idea工具中看看启动的信息,顺便看下启动的基本信息

在这里插入图片描述
可以看到信息有
tomcat版本
操作系统版本
java版本
tomcat 的CATALINA_BASE 和 CATALINA_HOME ,也就是tomcat 的安装版本
tomcat的jvm大小 等等基本信息
启动的时候也可以看下信息是否正确来确保你的项目启动没有问题
好了,正文开始,我们了解一下启动tomcat的日志信息
一般我们启动 startup.bat 的时候,启动成功会看到如下信息,

在图中我们可以看到,
【http-nio-8091】
【ajp-nio-8092】
这两行表示:
http 的方式是以nio 的模式来启动的
ajp 的方式是以nio 的模式来启动的
那么问题来了,http协议我们知道,ajp协议是什么??
看过tomcat的server.xml配置文件的,会了解到里面有这两个连接器
1)HTTP Connector
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000" redirectPort="8443" />
拥有这个连接器,Tomcat才能成为一个web服务器,还可以处理Servlet和jsp。
2)AJP Connector
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
AJP连接器可以通过AJP协议和另一个web容器进行交互。
到这里我们就知道,AJP 他的作用就是负责和其他的HTTP服务器建立连接
例如和apche服务器连接,有了这个协议,才可以把apche服务器和tomcat服务器给连接起来
那么 【http-nio-8091】 中的 http 和ajp 我们都了解了, 那么第二个参数nio是什么???
第二个参数代表的是tomcat的请求连接方式是什么样的。
在tomcat中连接方式一共有3种,往下看详解
tomcat有3种方式启动,分别是bio,nio,apr
什么是BIO NIO APR ?
BIO
bio是阻塞式IO操作,使用java io技术,即每一个请求都要创建一个线程来进行处理。缺点:并发量高时,线程数较多,占资源
NIO
使用java nio技术,能够通过少量的线程处理大量的请求
nio是基于java中非阻塞IO操作的API实现,比传统的i/o处理方式有更高的并发运行性能
APR
(Apache Portable Runtime/Apache可移植运行时库)
apr是从操作系统级别解决异步IO问题,大幅度提高服务器的并发处理性能,也是Tomcat生产环境运行的首选方式
如图
1)bio的启动信息

2)nio模式的启动信息

3)apr模式的启动信息

我们需要做的是把 http 和 ajp 都改成 用apr 的方式启动
tomcat8以及之后的版本默认都是以NIO的模式启动,如果要启动apr,需要自己设置
1)windows下设置用apr启动:
windows下已经安装有apr的支持,所以直接在service.xml文件中修改配置即可
找到以下这行
<Connector port="8091" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
修改成
<Connector port="8091" protocol="org.apache.coyote.http11.Http11AprProtocol" connectionTimeout="20000" redirectPort="8443" />
这样之后,http就是以apr的模式启动了,
效果如下

但是 ajp 没有启动apr,所以我们还需要再进行下一步操作
找到以下这行
<Connector port="8092" protocol="AJP/1.3" redirectPort="8443" />
修改成
<Connector port="8092" protocol="org.apache.coyote.ajp.AjpAprProtocol" redirectPort="8443" />
这样之后,ajp 就是以apr的模式启动了,
效果如下

HTTP和AJP 对应的协议,可以直接用前缀+协议名字填入到server.xml
例如  org.apache.coyote.http11.Http11NioProtocol
| HTTP | AJP | 
|---|---|
| 前缀 org.apache.coyote.http11 | 前缀 org.apache.coyote.ajp | 
| HTTP | Http11Protocol | Http11NioProtocol | Http11AprProtocol | 
| AJP | AjpProtocol | AjpNioProtocol | AjpAprProtocol | 
以上说的是在windows下开启apr,那么linux也是可以开启的,但是,linux默认没有安装apr的依赖,
所以需要我们自己安装,具体的安装内容会在我的下一篇博客,敬请期待~
最后来自网络的总结:
Apr处理请求最快,Nio次之,Bio最慢;
Apr宽带占用最高,Bio最低;但Apr的内存占用最高,而Nio的内存占用最低
所以综合来看,Nio适用于一般需求;Apr适用于高并发需求
tomcat启动nio,apr详解以及配置的更多相关文章
- Tomcat启动过程原理详解 -- 非常的报错:涉及了2个web.xml等文件的加载流程
		
Tomcat启动过程原理详解 发表于: Tomcat, Web Server, 旧文存档 | 作者: 谋万世全局者 标签: Tomcat,原理,启动过程,详解 基于Java的Web 应用程序是 ser ...
 - Tomcat负载均衡原理详解及配置(Apache2.2.19+Tomcat7.0.12)
		
结构图 JAVA项目一般直接用Tomcat作为Web服务器.为了增加tomcat的性能和稳定性,我们一般采用balance和session同步机制. 下图列出了我们常用也是最简单的解决方案. 说明 1 ...
 - Tomcat启动过程原理详解
		
基于Java的Web 应用程序是 servlet.JSP 页面.静态页面.类和其他资源的集合,它们可以用标准方式打包,并运行在来自多个供应商的多个容器.Web 应用程序存在于结构化层次结构的目录中,该 ...
 - Tomcat配置(二):tomcat配置文件server.xml详解和部署简介
		
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
 - Tomcat(二):tomcat配置文件server.xml详解和部署简介
		
Tomcat系列文章:http://www.cnblogs.com/f-ck-need-u/p/7576137.html 1. 入门示例:虚拟主机提供web服务 该示例通过设置虚拟主机来提供web服务 ...
 - log4j.properties 详解与配置步骤(转)
		
找的文章,供参考使用 转自 log4j.properties 详解与配置步骤 一.log4j.properties 的使用详解 1.输出级别的种类 ERROR.WARN.INFO.DEBUGERROR ...
 - tomcat bio nio apr 模式性能测试
		
转自:tomcat bio nio apr 模式性能测试与个人看法 11.11活动当天,服务器负载过大,导致部分页面出现了不可访问的状态.那后来主管就要求调优了,下面是tomcat bio.nio.a ...
 - 【转】联想笔记本进入u盘启动项操作方法详解
		
win7之家小编最近可是对联想笔记本进入u盘启动项的方法很有兴趣啊,那么联想进入u盘启动到底要怎么操作呢?其实方法是有的,因为小编就是研究联想进入u盘启动出身的,下面小编就给大家带来史上最详细的联想笔 ...
 - Java NIO 的前生今世 之四 NIO Selector 详解
		
Selector Selector 允许一个单一的线程来操作多个 Channel. 如果我们的应用程序中使用了多个 Channel, 那么使用 Selector 很方便的实现这样的目的, 但是因为在一 ...
 
随机推荐
- c++中利用宏定义简化for循环使用
			
话不多说,上方法 #define _for(i,a,b) for( int i=(a); i<(b); ++i) #define _rep(i,a,b) for( int i=(a); i< ...
 - 基于TCP协议的套接字编程
			
06.26自我总结 1.关于Socket Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在 ...
 - [小米OJ] 2. 找出单独出现的数字
			
解法一: map 1.45 ms #include <algorithm> #include <bitset> #include <cmath> #include ...
 - 如何在Eclipse中查看Java类库的源代码
			
你的JDK安装目录下%Java_home%/src.zip文件就是源码,解压缩找到对应包下面的类即可. 如果是Eclipse开发,ctr+鼠标左击,出现不了源码的话,在弹出的视图中点击attach s ...
 - MYSQL主从复制、主主复制、双主多从配置
			
一.如何配置MYSQL的主从复制? 1. 两台数据库服务器,IP分别为 192.168.216.128 和 192.168.216.129,在服务器上装MYSQL(我的配置版本为5.5.56) 2. ...
 - Spring 整合 ibatis
			
是的,真的是那个不好用的ibatis,不是好用的mybatis. 由于工作需要用到ibatis需要自己搭建环境,遇到了不少的坑,做一下记录. 一.环境配置 Maven JDK1.6 (非常重要,使用S ...
 - jmeter环境变量
			
jmeter环境变量配置jmeter环境变量时,同时也需要配置Java变量(jdk最好使用1.7及1.7以上的版本)1.配置jdk环境变量安装jdk正常安装,一路默认就好,记住安装路径,配置环境变量时 ...
 - 使用腾讯云提供的针对Nuget包管理器的缓存加速服务
			
继阿里巴巴开源镜像站(https://opsx.alibaba.com/).华为云镜像站点(https://mirrors.huaweicloud.com/ )之后,腾讯也已于近日上线了类似的服务,官 ...
 - Spring 核心技术(5)
			
接上篇:Spring 核心技术(4) version 5.1.8.RELEASE 1.4.5 自动装配协作者 Spring 容器可以自动连接协作 bean 之间的关系.你可以让 Spring 通过检查 ...
 - Consul和Kong的实践(一)
			
Consul和Kong的实践(一) 这一篇先介绍consul集群,以及consul和应用服务的结合使用,下一篇是和kong网关的结合. 一.Consul的集群安装 以其中一台机器为例: mkdir / ...