小计Tomcat的调优思路 | 必学必知

栏目: Java · 发布时间: 6年前

内容简介:最近,在补充自己的短板,刚好整理到 Tomcat 调优这块,基本上面试必问,于是就花了点时间去搜集一下 Tomcat 调优都调了些什么,先记录一下调优手段,更多详细的原理和实现以后用到时候再来补充记录,下面就来介绍一下,Tomcat 调优大致分为两大类。采用动静分离节约 Tomcat 的性能调整 Tomcat 的线程池

一、描述

最近,在补充自己的短板,刚好整理到 Tomcat 调优这块,基本上面试必问,于是就花了点时间去搜集一下 Tomcat 调优都调了些什么,先记录一下调优手段,更多详细的原理和实现以后用到时候再来补充记录,下面就来介绍一下,Tomcat 调优大致分为两大类。

1、Tomcat的自身调优

采用动静分离节约 Tomcat 的性能

调整 Tomcat 的线程池

调整 Tomcat 的连接器

修改 Tomcat 的运行模式

禁用 AJP 连接器

2、JVM的调优

调优Jvm内存

小计Tomcat的调优思路 | 必学必知

二、Tomcat 自身调优

1、采用动静分离

静态资源如果让 Tomcat 处理的话 Tomcat 的性能会被损耗很多,所以我们一般都是采用:Nginx+Tomcat 实现动静分离,让 Tomcat 只负责 jsp 文件的解析工作,Nginx 实现静态资源的访问。

2、调优 Tomcat 线程池

打开tomcat的serve.xml,配置Executor,相关参数说明如下。

小计Tomcat的调优思路 | 必学必知

name:给执行器(线程池)起一个名字;

namePrefix:指定线程池中的每一个线程的 name 前缀;

maxThreads:线程池中最大的线程数量,假设请求的数量超过了 750,这将不是意味着将 maxThreads 属性值设置为 750,它的最好解决方案是使用「Tomcat集群」。也就是说,如果有 1000 请求,两个 Tomcat 实例设置 maxThreads = 500,而不在单 Tomcat 实例的情况下设置 maxThreads=1000。

minSpareThreads:线程池中允许空闲的线程数量(多余的线程都杀死);

maxIdLeTime:一个线程空闲多久算是一个空闲线程;

其他的配置其实阅读官方文档是最好的「见参考链接」。

3、调优 Tomcat 的连接器 Connector

打开 Tomcat 的 serve.xml,配置 Connector,参数说明如下。

小计Tomcat的调优思路 | 必学必知

executor:指定这个连接器所使用的执行器(线程池);

小计Tomcat的调优思路 | 必学必知

enableLookups=false:关闭 DNS 解析,减少性能损耗;

minProcessors:服务器启动时创建的最少线程数;

maxProcessors:最大可以创建的线程数;

acceptCount=1000:线程池中的线程都被占用,允许放到队列中的请求数;

maxThreads=3000:最大线程数;

minSpareThreads=20:最小空闲线程数,这里是一直会运行的线程;

与压缩有关系的配置:如果已经对代码进行了动静分离,静态页面和图片等数据就不需要 Tomcat 处理了,那么也就不需要配置在 Tomcat 中配置压缩了;

一个完整的配置如下。

小计Tomcat的调优思路 | 必学必知

4、通过修改 Tomcat 的运行模式

BIO

Tomcat8 以下版本,默认使用的就是 BIO「阻塞式IO)」模式。

小计Tomcat的调优思路 | 必学必知

对于每一个请求都要创建一个线程来进行处理,不适合高并发。

NIO

Tomcat8 以上版本,默认使用的就是NIO模式「非阻塞式 IO」。

APR

全称 Apache Portable Runtime,是Tomcat生产环境运行的首选方式,如果操作系统未安装 APR 或者 APR 路径未指到 Tomcat 默认可识别的路径,则 APR 模式无法启动,自动切换启动 NIO 模式。所以必须要安装 APR 和 Native,直接启动就支持 APR,APR是从操作系统级别解决异步 IO 问题,APR 的本质就是使用 JNI 技术调用操作系统底层的 IO 接口,所以需要提前安装所需要的依赖

提升 Tomcat 对静态文件的处理性能,当然也可以采用动静分离。

5、禁用 AJP 连接器

AJP的全称 Apache JServer Protocol,使用 Nginx+Tomca t的架构,所以用不着 AJP 协议,所以把AJP连接器禁用。

小计Tomcat的调优思路 | 必学必知

三、JVM 调优

Tomcat 是运行在 JVM 上的,所以对 JVM 的调优也是非常有必要的。

找到 catalina.sh;

小计Tomcat的调优思路 | 必学必知

添加;

小计Tomcat的调优思路 | 必学必知

参数设置;

JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8-server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:MaxNewSize=512m -XXermSize=512m -XX:MaxPermSize=512m -XX:+DisableExplicitGC"

调整堆大小的的目的是最小化垃圾收集的时间,以在特定的时间内最大化处理客户的请求。

参考

https://tomcat.apache.org/tomcat-8.0-doc/config/executor.html

https://tomcat.apache.org/tomcat-8.0-doc/config/index.html


以上所述就是小编给大家介绍的《小计Tomcat的调优思路 | 必学必知》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

如何不在网上虚度人生

如何不在网上虚度人生

[美] 肯尼思·戈德史密斯 / 刘畅 / 北京联合出版公司 / 2017-9 / 39.80元

我们平时上网多大程度上是浪费时间,多大程度是在学习、关心社会、激发创造力?我们真能彻底断网,逃离社交网络吗? 手机把都市人变成一群电子僵尸,是福是祸? 浏览记录就是我们将来的回忆录吗?文件归档属于一种现代民间艺术? 不自拍、P图、发朋友圈,我还是我吗? 美国知名概念艺术家戈德史密斯认为:上网绝不是浪费时间,而是一种创造性的活动。在本书中他以跨学科角度、散文式语言进行论证,涉及大众传播学、计算......一起来看看 《如何不在网上虚度人生》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具