美团二面惜败,惊了!我这样优化了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连接

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

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

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

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

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

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

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

image.png

重启tomcat,查看效果:

惊了!我这样优化了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 初始化时创建的线程数,默认设置 25
	prestartminSpareThreads:在Tomcat初始化的时候就初始化 minSpareThreads 的参数值,如果不等于true ,minSpareThreads 的值就没啥效果了
	maxQueueSize:最大的等待队列数,超过则拒绝请求
-->

   <!-- 在Connector中设置 executor 属性指向上面的执行器 -->
    <Connector executor="tomcatThreadPool" port="8000" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

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

惊了!我这样优化了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" />

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

四、性能测试

4.1 使用Apache Jmeter 进行测试

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

4.1.1 下载安装

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

image.png

进入bin目录,找到meter.bat文件,双击打开即可启动。

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

注意:如果想要效果更好的体现最好使用一个项目demo进行测试

4.1.2 配置

第一步:保存测试用例

image.png

第二步:添加线程组,使用线程模拟用户的并发

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

1000个线程,每个线程循环10次,也就是tomcat会接收到10000个请求

image.png

第三步:添加http请求
这里我使用的是我的测试项目

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

image.png

第四步:添加请求监控

image.png

4.1.3 启动测试:

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

其中我们需要关注的就是 聚合报告 的数据

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

4.2 禁用AJP服务

惊了!我这样优化了Tomcat后,网站访问性能竟飙升

image.png

总结

大型分布式系统犹如一个生命,系统中各个服务犹如骨骼,其中的数据犹如血液,而Kafka犹如经络,串联整个系统。这份Kafka源码笔记通过大量的设计图展示、代码分析、示例分享,把Kafka的实现脉络展示在读者面前,帮助读者更好地研读Kafka代码。

需要免费领取这份Kafka源码笔记的铁汁们,麻烦帮忙转发一下这篇文章+关注我,然后戳这里免费获取!

afka源码笔记通过大量的设计图展示、代码分析、示例分享,把Kafka的实现脉络展示在读者面前,帮助读者更好地研读Kafka代码。

需要免费领取这份Kafka源码笔记的铁汁们,麻烦帮忙转发一下这篇文章+关注我,然后戳这里免费获取!

就这一次!拼多多内部架构师培训Kafka源码笔记(现已绝版)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值