背景

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

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

tomcat的使用

下载

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

5种下载包的区别

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

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 

  1. <role rolename='admin' />
  2. ...
  3. <user username='admin' password='admin' roles='admin,admin-gui,admin-script,
  4. manager-script,manager-gui,manager-jmx,manager-status' />

监控页面如下图:


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

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

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

tomcat的IO调优

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

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

APR优化IO

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

NIO优化老版本的BIO

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

老的配置:

  1. <connector protocol="HTTP/1.1" />

新的配置:

  1. //tomcat6选择nio1
  2. <connector protocol="org.apache.coyote.http11.Http11NioProtocol" />
  3. //tomcat8选择nio2,apr性能更好
  4. <connector protocol="org.apache.coyote.http11.Http11Nio2Protocol" />
  5. <connector protocol="org.apache.coyote.http11.Http11AprProtocol" />

tomcat的线程池调优

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

线程池参数:

定义线程池

  1. <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
  2. maxThreads="150" minSpareThreads="4"/>

配置Connector启用

  1. <connector executor="tomcatThreadPool">

connector参数

tomcat的jvm参数调优

GC优化

  1. #gc优化
  2. JAVA_GC="-XX:SurvivorRatio=10
  3. -XX:MaxTenuringThreshold=15
  4. -XX:NewRatio=2
  5. -XX:+DisableExplicitGC
  6. -Djava.security.egd=file:/dev/./urandom"

jvm和线程池优化

  1. JVM_LEVEL="info"
  2. JVM_Xms="100m"
  3. JVM_Xmx="2048m"
  4. JVM_Xmn="600m"
  5. JVM_Xss="256k"
  6. TOMCAT_acceptCount=4096 线程可以接受的请求数量
  7. TOMCAT_maxThreads=512 最大线程数
  8. TOMCAT_minSpareThreads=512 初始线程数

小结

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

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

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

原创不易,点赞关注支持一下吧!转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。
我会持续分享Java软件编程知识和程序员发展职业之路,欢迎关注,我整理了这些年编程学习的各种资源,关注公众号‘李福春持续输出’,发送'学习资料'分享给你!

面试刷题32:你对tomcat做了哪些性能调优?的更多相关文章

  1. Tomcat和JVM的性能调优总结

    Tomcat性能调优: 找到Tomcat根目录下的conf目录,修改server.xml文件的内容.对于这部分的调优,我所了解到的就是无非设置一下Tomcat服务器的最大并发数和Tomcat初始化时创 ...

  2. 《Tomcat和JVM的性能调优你真的学会了吗?》总结篇

    Tomcat性能调优: 找到Tomcat根目录下的conf目录,修改server.xml文件的内容.对于这部分的调优,我所了解到的就是无非设置一下Tomcat服务器的最大并发数和Tomcat初始化时创 ...

  3. 一份 Tomcat 和 JVM 的性能调优经验总结!拿走不谢

    Tomcat性能调优 找到Tomcat根目录下的conf目录,修改server.xml文件的内容.对于这部分的调优,我所了解到的就是无非设置一下Tomcat服务器的最大并发数和Tomcat初始化时创建 ...

  4. 性能优化 | Tomcat和JVM的性能调优总结

    Tomcat性能调优: 找到Tomcat根目录下的conf目录,修改server.xml文件的内容.对于这部分的调优,我所了解到的就是无非设置一下Tomcat服务器的最大并发数和Tomcat初始化时创 ...

  5. Tomcat修改service.xml性能调优 增加最大并发连接数

    详细配置: <Connector executor="tomcatThreadPool"               port="80" protocol ...

  6. Tomcat高级特性及性能调优

    Tomcat对Https的支持 HTTPS简介 Https,是以安全为目标的Http通道,在Http的基础上通过传输加密和身份认证保证了传输的安全性.HTTPS在HTTP的基础上加入SSL层,HTTP ...

  7. tomcat 9.0.4 性能调优

    参考了网上的一些优化参数,但是在启动中发现 有2个报错: 11-Feb-2018 15:57:23.293 警告 [main] org.apache.catalina.startup.SetAllPr ...

  8. 安利一个基于Spring Cloud 的面试刷题系统。面试、毕设、项目经验一网打尽

    推荐: 接近100K star 的Java学习/面试指南 Github 95k+点赞的Java面试/学习手册.pdf 今天给小伙伴们推荐一个朋友开源的面试刷题系统. 这篇文章我会从系统架构设计层面详解 ...

  9. 面试官:怎么做JDK8的内存调优?

    面试官:怎么做JDK8的内存调优? 看着面试官真诚的眼神,心中暗想看起来年纪轻轻却提出如此直击灵魂的问题.擦了擦额头上汗,我稍微调整了一下紧张的情绪,对面试官说: 在内存调优之前,需要先了解JDK8的 ...

随机推荐

  1. 广告行业中那些趣事系列6:BERT线上化ALBERT优化原理及项目实践(附github)

    摘要:BERT因为效果好和适用范围广两大优点,所以在NLP领域具有里程碑意义.实际项目中主要使用BERT来做文本分类任务,其实就是给文本打标签.因为原生态BERT预训练模型动辄几百兆甚至上千兆的大小, ...

  2. 关于独立部署web项目到tomcat服务器详情

    步骤: 1.设置端口号:找到所解压的tomcat的目录下中的conf文件夹,再用editPlus打开conf文件夹中的server.xml文件,tomcat初始端口为8005,8080,8009,如果 ...

  3. Serializable详解(1):代码验证Java序列化与反序列化

    说明:本文为Serializable详解(1),最后两段内容在翻译上出现歧义(暂时未翻译),将在后续的Serializable(2)文中补充. 介绍:本文根据JDK英文文档翻译而成,本译文并非完全按照 ...

  4. 必备技能七、Vuex

    这段时间一直在用vue写项目,vuex在项目中也会依葫芦画瓢使用,但是总有一种朦朦胧胧的感觉.于是决定彻底搞懂它. 看了一下午的官方文档,以及资料,才发现vuex so easy! 作为一个圈子中的人 ...

  5. 一起了解 .Net Foundation 项目 No.17

    .Net 基金会中包含有很多优秀的项目,今天就和笔者一起了解一下其中的一些优秀作品吧. 中文介绍 中文介绍内容翻译自英文介绍,主要采用意译.如与原文存在出入,请以原文为准. Peachpie Comp ...

  6. 【已解决】HDFS节点已经启动,但不能访问50070 ?

    问题描述 通过start-dfs.sh启动了三个节点 但无法通过IP访问50070端口 问题分析 1.可能是防火墙没关,被拦截了 果然,防火墙没关 再将防火墙设为开机不启动 systemctl dis ...

  7. Spyder——科学的Python开发环境

    刚开始接触Python的时候,网上找到的资料基本上上来就是介绍Python语言,很少有对开发环境进行讲解的,但如果在学习的过程中不断练习,这样效率会更高,所以特意将一个Python的开发环境Spyde ...

  8. 【Weiss】【第04章】二叉搜索树例程

    [二叉搜索树] 随机生成时平均深度为logN,平均插入.删除和搜索时间都是O(logN). 可能存在的问题是数据不均衡,使树单边生长,极端情况下变成类似链表,最坏插入.删除.搜索时间O(N) 写这个例 ...

  9. nuxt创建项目的步骤

    nuxt创建项目的步骤 1.基本步骤 // 创建package.json依赖管理文件 npm init -y // 在package.json文件中添加运行nuxt的命令,之后npm run dev启 ...

  10. vue使用lodop打印控件实现浏览器兼容打印

    前言 此控件直接进行打印底部会有水印,通过官网购买可以解决: 如不想购买,可先执行预览,弹出预览框进行打印: 需要用到的js文件和api文档附后,请注意查看. 首先需要在局部或全局引入LodopFun ...