一、前言

tomcat 服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了,对于tomcat的优化,主要是从2个方面入手,一是tomcat本身的配置,另一个是tomcat所运行的Jvm虚拟机的调优

二、Tomcat配置优化

2.1 下载安装tomcat

案例中使用的Tomcat版本是 8.0+ 版本

下载安装:https://tomcat.apache.org/download-80.cgi

2.2 配置修改

cd apache-tomcat-8.5.47/conf/ 进入tomcat配置文件夹

vim tomcat-users.xml 需要配置文件,配置tomcat的管理用户

写入以下内容:

  <role rolename="manager"/><role rolename="manager-gui"/><role rolename="admin"/><role rolename="admin-gui"/><user username="tomcat" password="tomcat" roles="admin-gui,admin,manager-gui,manager"/># 保存退出
# 如果是tomcat7,配置了tomcat用户就可以登录系统了,但是tomcat8中不行,还需要修改下面一个配置文件,否则访问不了,提示403vim  cd webapps/manager/META-INF/context.xml
<Context antiResourceLocking="false" privileged="true" >
<!--  <Valve className="org.apache.catalina.valves.RemoteAddrValve"allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />  --><Manager sessionAttributeValueClassNameFilter="java\.lang\.(?:Boolean|Integer|Long|Number|String)|org\.apache\.catalina\.filters\.CsrfPreventionFilter\$LruCache(?:\$1)?|java\.util\.(?:Linked)?HashMap"/>
</Context># 保存退出即可
# 启动tomcat

2.33 启动访问

成功访问tomcat地址后,点击 首页中Server Status,输入用户名密码tomcat/tomcat

进入页面,我们需要关注的就是其中JVM的列表参数:
Eden Space:年轻代中的Eden区
Survivor Space:年轻代中的Survivor 区
Tenured Gen:老年代-养老区
其中Eden Space、Survivor Space、Tenured Gen属于堆内存,而下面的三个(Code Cache、Compressed Class Space、Metaspace)属于非堆内存

Code Cache:代码缓存区
Compressed Class Space:压缩类空间
Metaspace:元空间

三、Tomcat优化

3.1 禁用AJP连接

在服务状态页面可以看到,默认状态下会启用AJP连接,并且占用8011端口

什么是AJP呢?
AJP(Apache jServer Protocol)
AJP13协议是面向包的,WEB服务器和Servlet容器通过TCP连接来交互;为了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP容器,并且在多个请求赫尔响应周期过程会重用连接。

web客户端访问tomcat服务器上的JSP组件的两种方式,如下图所示:

我们一般是使用Nginx+tomcat的架构,所以用不着AJP协议,所以把AJP连接禁用。
修改conf下的Server.xml文件,将AJP服务禁用掉即可。

<Connector port="8011" protocol="AJP/1.3" redirectPort="8443" />

重启tomcat,查看效果:

可以看到AJP服务已经不存在了

3.2 执行器(线程池)

在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能
修改conf/server.xml文件:

 <!--将注释打开--><Executor name="tomcatThreadPool" namePrefix="catalina-exec-"maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/><!--参数说明:maxThreads:最大并发数,默认设置 200 ,一般建议在 500-1000,根据硬件设施和业务来判断minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25prestartminSpareThreads:在Tomcat初始化的时候就初始化 minSpareThreads 的参数值,如果不等于true ,minSpareThreads 的值就没啥效果了maxQueueSize:最大的等待队列数,超过则拒绝请求
--><!-- 在Connector中设置 executor 属性指向上面的执行器 --><Connector executor="tomcatThreadPool" port="8000" protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="8443" />

保存退出,重启tomcat,查看效果

在页面中显示最大线程为 -1 ,这个是正常的,只是显示的问题,实际使用的指定的值

3.3 tomcat的三种运行模式

tomcat的运行模式有三种:

  • bio: 默认的模式,性能非常低下,没有经过任何优化处理和支持
  • nio: (new I/O),是Java SE 1.4及后续版本提供的一种新的 I/O操作方式(即java.nio包及其子包),java nio是一个基于缓冲区,并能提供非阻塞I/O操作的java API ,因此nio也被看成是 non-blocking I/O的缩写,它拥有比传统I/O操作(bio)更好的并发运行性能
  • apr: 安装起来最困难,不过在tomcat8中有最新的nio2,速度更快,建议使用nio2

设置nio2:

<Connector executor="tomcatThreadPool" port="8000" protocol="org.apache.coyote.http11.Http11Nio2Protocol"connectionTimeout="20000"redirectPort="8443" />

四、性能测试

4.1 使用Apache Jmeter 进行测试

Apache Jmeter 是开源的压力测试工具,我们借助此工具进行测试,将测试出tomcat的吞吐量等信息

4.1.1 下载安装

下载地址:http://jmeter.apache.org/download_jmeter.cgi

是开源的压力测试工具,我们借助此工具进行测试,将测试出tomcat的吞吐量等信息

4.1.1 下载安装

下载地址:http://jmeter.apache.org/download_jmeter.cgi

[外链图片转存中…(img-z6xwkynx-1628341369495)]

Java中高级面试题总结(全面),惊了!我这样优化了Tomcat后相关推荐

  1. Java中高级面试题 -- 数十道题含答案

    Java中高级面试题 一.基础知识: 1)集合类:List和Set比较,各自的子类比较(ArrayList,Vector,LinkedList:HashSet,TreeSet): ArrayList ...

  2. Java中高级面试题部分答案解析

    Java中高级面试题部分答案解析 List和Set比较,各自的子类比较 对比一:Arraylist与LinkedList的比较 1.ArrayList是实现了基于动态数组的数据结构,因为地址连续,一旦 ...

  3. Java中高级面试题部分答案解析(3)

    点击上方"Java知音",选择"置顶公众号" 技术文章第一时间送达! 知音专栏 Javaweb练手项目源码下载 常用设计模式完整系列篇 100套IT类简历模板下 ...

  4. java中高级面试题整理

    java中高级面试题整理                  问题                                                                     ...

  5. java面试题(java中高级面试题及答案)

    [java面试题] 1.Collections.sort排序内部原理 在Java6Arrays.sort()和Collections.sort()中使用MergeSort,在Java7中,内部实现被T ...

  6. 100道Java中高级面试题汇总+详细拆解

    出自:Java面试题精选 1-10期 [10期]Redis 面试常见问答 [09期]说说hashCode() 和 equals() 之间的关系? [08期]说说Object类下面有几种方法呢? [07 ...

  7. 【Java从0到架构师(1),Java中高级面试题总结(全面)

    JSP 九大内置对象 MySQL 基础 + 多表查询 [Java从0到架构师]MySQL 基础 MySQL MySQL 的使用步骤 数据库的内部存储细节 GUI 工具 SQL 语句 DDL 语句 DD ...

  8. 阿里最新秋招面经,腾讯/美团/字节1万道Java中高级面试题

    又是一年过去了,职场的积雪还没有消融,又迎来了一次大考.疫情还没完全过去,大家强打起精神,相互问好致意,眼角却满是疲惫- 企业调薪.裁员.组织架构调整等等,坏消息只多不少,最近也有很多来咨询跳槽的朋友 ...

  9. 阿里最新春招面经,腾讯 / 美团 / 字节 1 万道 Java 中高级面试题

    我梳理了各个大厂春秋招面经分享,分享上万道面试题及答案,从实习生到开发 1-10 年的简历模板,面试过程的文档教程! 阿里常问面试题(1-5 年经验) String,StringBuffer,Stri ...

最新文章

  1. [WC2018]通道——边分治+虚树+树形DP
  2. 通过PSO实现不同函数的目标值计算和搜索
  3. 在django中使用celery
  4. 【笛卡尔树】【树状数组】Beautiful Pair(P4755)
  5. 【知识积累】DES算法之C#加密Java解密
  6. 【操作系统】—线程概念和多线程模型
  7. office是python打开方式_Python读取word文本操作详解
  8. 游戏和数学笔记—常拿起来看看
  9. Linux服务器生成https证书
  10. NetBIOS协议和NBNS协议
  11. TMS320C6455之DDR2内存控制器
  12. Python解压zip和rar文件
  13. MACD回零轴有三种方式
  14. 【平面设计基础】03:绘制—图标到底有多重要
  15. excel如何把顺序倒过来_excel怎么把顺序倒过来
  16. cs与msf联动概述
  17. Android中的英文翻译
  18. JAVA应用生产问题排查步骤
  19. 多标签分类方法总结——实现方法、评价指标、损失函数
  20. 出行必备:手机1秒调出健康码 !

热门文章

  1. boost库使用串口
  2. csr文件(csr文件是什么)
  3. 阻止网络钓鱼诈骗的技巧
  4. 【深度学习】模型评价指标
  5. IOS重写unity Splash,消除黑屏,播放开场动画视频
  6. 不买房做什么都是不务正业
  7. Flink 六脉神剑秘诀
  8. 七种常见的排序算法总结
  9. 2022 最新 Android 基础教程,从开发入门到项目实战【b站动脑学院】学习笔记——第一章:Android开发环境搭建
  10. STM32使用MPU6050在TFT_LCD上显示数据