tomcat的最佳实践运行模式

Tomcat Connector三种运行模式(BIO, NIO, APR)的比较和优化。

org.apache.coyote.http11.Http11Protocol:BIO
org.apache.coyote.http11.Http11NioProtocol:NIO
org.apache.coyote.http11.Http11Nio2Protocol:NIO2
org.apache.coyote.http11.Http11AprProtocol:APR

三种比较

BIO
一个线程处理一个请求。缺点:并发量高时,线程数较多,浪费资源。Tomcat7或以下,在Linux系统中默认使用这种方式。
NIO
利用Java的异步IO处理,可以通过少量的线程处理大量的请求。Tomcat8在Linux系统中默认使用这种方式。Tomcat7必须修改Connector配置来启动:
<Connector port="8080"
protocol="org.apache.coyote.http11.Http11NioProtocol"
connectionTimeout="20000"
redirectPort="8443"/>

Tomcat8以后NIO2模式:
<Connector port="8080"
protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="20000"
redirectPort="8443"/>

APR
即Apache Portable Runtime,从操作系统层面解决io阻塞问题。Tomcat7或Tomcat8在Win7或以上的系统中启动默认使用这种方式。Linux如果安装了apr和native,Tomcat直接启动就支持apr。
连接池
默认值:
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="150" minSpareThreads="4"/>

修改为:
<Executor
name="tomcatThreadPool"
namePrefix="catalina-exec-"
maxThreads="500"
minSpareThreads="100"
prestartminSpareThreads = "true"
maxQueueSize = "100"
/>

参数解释:
maxThreads,最大并发数,默认设置 200,一般建议在 500 ~ 800,根据硬件设施和业务来判断
minSpareThreads,Tomcat 初始化时创建的线程数,默认设置 25
prestartminSpareThreads,在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就没啥效果了
maxQueueSize,最大的等待队列数,超过则拒绝请求

默认的链接参数配置:
<Connector
port="8080"
protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
/>

修改为:
<Connector executor="tomcatThreadPool"
port="8080"
protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="20000"
redirectPort="8443"/>

参数解释:
protocol,Tomcat 8 设置 nio2 更好:org.apache.coyote.http11.Http11Nio2Protocol
protocol,Tomcat 6、7 设置 nio 更好:org.apache.coyote.http11.Http11NioProtocol
enableLookups,禁用DNS查询
acceptCount,指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理,默认设置 100
maxPostSize,以 FORM URL 参数方式的 POST 提交方式,限制提交最大的大小,默认是 2097152(2兆),它使用的单位是字节。10485760 为 10M。如果要禁用限制,则可以设置为 -1
acceptorThreadCount,用于接收连接的线程的数量,默认值是1。一般这个指需要改动的时候是因为该服务器是一个多核CPU,如果是多核 CPU 一般配置为 2

端口配置
Tomcat服务器需配置三个端口才能启动,安装时默认启用了这三个端口,当要运行多个tomcat服务时需要修改这三个端口。
<!-- 端口-1即可,标识随机 -->
<Server port="-1" shutdown="SHUTDOWN">

<!-- 访问端口,必须配置 -->
<Connector port="8080"
protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="20000"
redirectPort="8443"/>

<!-- 配置Apache使用,如果使用Nginx代理注释掉即可 -->
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

最新文章

  1. Mac 效率工具
  2. HTML5和CSS3新特性一览
  3. Auto Mapper02《demo》
  4. C语言 ---- 函数 结构体 iOS学习-----细碎知识点总结
  5. bll编译错误
  6. eclipse几个注意的地方
  7. 修改php.ini以达到 屏蔽错误信息
  8. [译]JavaScript insertAdjacentHTML
  9. SpringMVC控制器接收不了PUT提交的参数的解决方案
  10. javascript判断浏览器是否是隐私模式
  11. JS操作性能优化
  12. c++中宽字节表示
  13. 安装cocoapods遇到的一些问题
  14. Django REST framework+Vue 打造生鲜超市(八)
  15. IDEA+Maven+各个分支代码进行合并
  16. Python3实现自动点赞抖音小姐姐
  17. BBC记录片之非洲4
  18. BZOJ4997 [Usaco2017 Feb]Why Did the Cow Cross the Road III
  19. 关于tcp中time_wait状态的4个问题
  20. LeetCode 706 Design HashMap 解题报告

热门文章

  1. hibernate 单元测试
  2. Ubuntu 开启telnet、ftp服务
  3. rsync 简单使用 非默认ssh端口 分别从远程获取及推送本地的文件到远程
  4. leetcode661
  5. ARQ
  6. 框架之 hibernate之各种查询
  7. STM32 C++编程 003 USART(串口)类
  8. ZROI2018提高day4t3
  9. python3-file的修改实现类似shell中sed的功能
  10. yzm10的职业生涯