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 很方便的实现这样的目的, 但是因为在一 ...
随机推荐
- duilib加消息
一.加消息 1. public INotifyUI, 2. void Notify(TNotifyUI& msg); 3. Notify实现 4. m_pManager->AddNoti ...
- 高德网络定位之“移动WiFi识别”
导读随着时代的发展,近10年来位置产业蓬勃发展,定位能力逐渐从低精度走向高精度,从部分场景走向泛在定位.设备和场景的丰富,使得定位技术和能力也不断的优化更新.定位能力包括GNSS.DR(航迹推算).M ...
- [PTA] 数据结构与算法题目集 6-10 二分查找
Position BinarySearch(List L, ElementType X) { int beg = 1; int end = L->Last; while (beg <= e ...
- linux中type 、file、stat三者的区别
1.type 用来查看命令类型,以区别是内部命令还是外部命令 示例:[root@localhost ~]# type cd cd 是 shell 内嵌 [root@localhost ~]# t ...
- Java的几种创建实例方法的性能对比
近来打算自己封装一个比较方便读写的Office Excel 工具类,前面已经写了一些,比较粗糙本就计划重构一下,刚好公司的电商APP后台原有的导出Excel实现出现了可怕的性能问题,600行的数据生成 ...
- cachestat 安装文档
安装环境:ubuntu18.04 安装步骤 1. 打开命令行,输入以下命令 sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys ...
- ld: warning: directory not found for option ''
iOS开发中经常遇到这样的警告,如图所示: 原因是存在未用到的目录. 解决方法:选择Build Settings,找到Search Paths中的Library Search Paths,如下图 删除 ...
- Java集合系列(三):HashSet、LinkedHashSet、TreeSet的使用方法及区别
本篇博客主要讲解Set接口的三个实现类HashSet.LinkedHashSet.TreeSet的使用方法以及三者之间的区别. 注意:本文中代码使用的JDK版本为1.8.0_191 1. HashSe ...
- MyBatis 核心配置综述之StatementHandler
目录 MyBatis 核心配置综述之StatementHandler MyBatis 四大组件之StatementHandler StatementHandler 的基本构成 StatementHan ...
- hadoop大数据平台安全基础知识入门
概述 以 Hortonworks Data Platform (HDP) 平台为例 ,hadoop大数据平台的安全机制包括以下两个方面: 身份认证 即核实一个使用者的真实身份,一个使用者来使用大数据引 ...