linux tomcat优化配置_面试刷题32:你对tomcat做了哪些性能调优?

63abc5577becdf239a654930d5236fe6.png

背景

java程序员的开发的java应用程序,一般都会选择使用tomcat发布,但是: 如何充分的掌控tomcat,并让它发挥最优性能呢?

这也是面试的热点问题,结合多年的工作实践,我是李福春,今天总结一下。

tomcat的使用

下载

现在最新的稳定版本是tomcat9, 下载页面:https://tomcat.apache.org/download-90.cgi

5种下载包的区别

043840f7bc6849bf491127976184b3c6.png

tomcat不同下载包区别

一般我们选择的是 core包运行tomcat,或者直接选择docker的镜像来运行;

tomcat的目录说明:

474e3dceddf9784194ccc43344dd48bc.png

tomcat的目录说明

安装

直接解压即可,解压指令:tar -zxvf tomcat-xxx.tar.gz

启动和停止

按照running.txt中的说明指导, 两种方式启动:

1, sh ${catalina.home}/bin/startup.sh 2, sh ${catalina.home}/bin/catalina.sh start

对应的两种方式停止tomcat:

1, sh ${catalina.home}/bin/shutdown.sh 2, sh ${catalina.home}/bin/catalina.sh stop

日志

tomcat产生的日志分成4类

1, catalina.date.out 最近的所有级别的日志; 2,localhost-date.log 错误日志

实时查看日志指令: tail -f catalina.out

AJP协议

一般用在tomcat跟其它HTTP服务器建立连接。

比如Apache+Tomcat做动静态分离:

apache处理所有的静态资源;

apache通过JK(负载均衡组件)转发动态资源请求到Tomcat,通过AJP协议。

tomcat的监控

保留默认tomcat下的webapps的 ROOT, host-manager , manager 应用,就可以监控单个tomcat节点的状态。

默认是不可以访问的,需要增加用户和权限才能看到,否则会报403;

增加方法: conf/tomcat-user.xml
...

监控页面如下图:

882c44e1cf76beffe08433e9e1f815d9.png

server status: 可以看到tomcat和jvm的版本信息,jvm的分区信息,tomcat内部线程池状态;

11e5445858d4c40e0599e47cfee321f3.png

manager-app: 管理tomcat下运行的应用,提供控制按钮,启动,停止,重启,卸载,以及不停服安装新的应用;

b5464ddeb259ee6d505f2d8ece6eb9cd.png

host-manger:提供了虚拟主机的管理,即配置别名和二级路径到tomcat的应用。

d6584b354bfd870eb9471d7788671f63.png

tomcat的IO调优

tomcat9中默认使用的nio处理java的io. 可以从日志中和配置文件中看到。

09-Apr-2020 07:46:27.606 信息 [main] org.apache.coyote.AbstractProtocol.start 开始协议处理句柄["http-nio-8080"]

APR优化IO

使用apr(Apache Portable Runtime),从操作系统层面解决了异步io的问题,可以大幅度提高性能。 如果linux安装了apr和tomcat-native,则tomcat启动就支持了apr;

NIO优化老版本的BIO

老版本的tomcat如果采用了BIO(通过日志可以看出),可以调整为NIO,调整方法: conf/server.xml

老的配置:

新的配置:

//tomcat6选择nio1//tomcat8选择nio2,apr性能更好

tomcat的线程池调优

tomcat默认不启用线程池,可以启用线程池提高线程的利用率

线程池参数:

ae8d9cadee3160a398bbca09107371c3.png

定义线程池

    

配置Connector启用

connector参数

7872a4e7073f1b53dca2d2ba9eea972a.png

tomcat的jvm参数调优

GC优化

#gc优化JAVA_GC="-XX:SurvivorRatio=10 -XX:MaxTenuringThreshold=15 -XX:NewRatio=2 -XX:+DisableExplicitGC -Djava.security.egd=file:/dev/./urandom"
c551490da6a31cb7fbb120e05ae07d36.png

jvm和线程池优化

JVM_LEVEL="info"JVM_Xms="100m"JVM_Xmx="2048m"JVM_Xmn="600m"JVM_Xss="256k"TOMCAT_acceptCount=4096 线程可以接受的请求数量TOMCAT_maxThreads=512 最大线程数TOMCAT_minSpareThreads=512 初始线程数
a800077448b3c803e13018f7c69593e9.png

小结

本篇回顾了tomcat的基础知识。

以及使用tomcat内置的监控程序对java应用进行监控的一些基础知识点。

然后结合工作经验,从io,线程池,jvm三个方面对tomcat进行调优

原创不易,点赞关注支持一下吧!转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。 我会持续分享Java软件编程知识和程序员发展职业之路,欢迎关注!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值