JVM性能优化(四)提高网站访问性能之Tomcat优化(1)

简介: JVM性能优化(四)提高网站访问性能之Tomcat优化

一、前言

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

二、Tomcat配置优化

2.1 下载安装tomcat

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

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

image.png

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中不行,还需要修改下面一个配置文件,否则访问不了,提示403
  vim  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 启动访问

image.png

成功访问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:元空间


image.png

三、Tomcat优化


3.1 禁用AJP连接

image.png

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


什么是AJP呢?

AJP(Apache jServer Protocol)

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


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

image.png

我们一般是使用Nginx+tomcat的架构,所以用不着AJP协议,所以把AJP连接禁用。

修改conf下的Server.xml文件,将AJP服务禁用掉即可。


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


重启tomcat,查看效果:

image.png

可以看到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 初始化时创建的线程数,默认设置 25
  prestartminSpareThreads:在Tomcat初始化的时候就初始化 minSpareThreads 的参数值,如果不等于true ,minSpareThreads 的值就没啥效果了
  maxQueueSize:最大的等待队列数,超过则拒绝请求
-->
   <!-- 在Connector中设置 executor 属性指向上面的执行器 -->
    <Connector executor="tomcatThreadPool" port="8000" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />


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

image.png


在页面中现实最大线程为 -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" />

image.png

目录
相关文章
|
4月前
|
缓存 安全 算法
Java面试题:如何通过JVM参数调整GC行为以优化应用性能?如何使用synchronized和volatile关键字解决并发问题?如何使用ConcurrentHashMap实现线程安全的缓存?
Java面试题:如何通过JVM参数调整GC行为以优化应用性能?如何使用synchronized和volatile关键字解决并发问题?如何使用ConcurrentHashMap实现线程安全的缓存?
41 0
|
21天前
|
Arthas 监控 Java
JVM知识体系学习七:了解JVM常用命令行参数、GC日志详解、调优三大方面(JVM规划和预调优、优化JVM环境、JVM运行出现的各种问题)、Arthas
这篇文章全面介绍了JVM的命令行参数、GC日志分析以及性能调优的各个方面,包括监控工具使用和实际案例分析。
37 3
|
20天前
|
存储 算法 Java
深入理解Java虚拟机(JVM)及其优化策略
【10月更文挑战第10天】深入理解Java虚拟机(JVM)及其优化策略
34 1
|
1月前
|
监控 Java
Java的JVM如何优化?
Java的JVM如何优化?
51 3
|
2月前
|
网络协议 Java 应用服务中间件
Tomcat 性能优化
Tomcat 性能优化
40 2
|
3月前
|
Java 应用服务中间件 Apache
使用IDEA修改Web项目访问路径,以及解决Apache Tomcat控制台中文乱码问题
本文介绍了在IntelliJ IDEA中修改Web项目访问路径的步骤,包括修改项目、模块、Artifacts的配置,编辑Tomcat服务器设置,以及解决Apache Tomcat控制台中文乱码问题的方法。
141 0
使用IDEA修改Web项目访问路径,以及解决Apache Tomcat控制台中文乱码问题
|
4月前
|
缓存 Prometheus 监控
Java面试题:如何监控和优化JVM的内存使用?详细讲解内存调优的几种方法
Java面试题:如何监控和优化JVM的内存使用?详细讲解内存调优的几种方法
91 3
|
4月前
|
前端开发 Java 应用服务中间件
Tomcat 与 JVM 中classpath的理解和设置总结
Tomcat 与 JVM 中classpath的理解和设置总结
195 0
|
4月前
|
监控 Java 中间件
FGC频繁导致CPU 飙升定位及JVM配置优化总结
FGC频繁导致CPU 飙升定位及JVM配置优化总结
141 0
|
4月前
|
存储 设计模式 监控
Java面试题:简述JVM的内存结构,包括堆、栈、方法区等。栈内存优化的方法有 哪些?
Java面试题:简述JVM的内存结构,包括堆、栈、方法区等。栈内存优化的方法有 哪些?
45 0