Tomcat重启负载高问题定位

发表于:2014-1-08 11:54

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:侯本文    来源:51Testing软件测试网采编

  尝试的解决方法:
  helloJava的两篇文章中给出了两种配置方法:见:http://hellojava.info/?p=195以及http://hellojava.info/?p=201
  尝试加上-XX:+TieredCompilation,期望借助多层编译来缓解这个问题:
  在tomcatjvm参数中增加该配置项,资源监控CPU飙高持续时间降低到45s左右,比原来少了10s+,略有效果
  尝试加一个-XX:CICompilerCount参数来试试,这个值默认是2,也就是说2个c2的编译线程来进行编译:
  因为QA19和线上tomcat应用服务器都是2个核的云主机,所以默认值2应该是最优值,尝试把该值改成1or4,没有起到优化效果。
  存在问题:
  对于QA19性能测试环境来说,重启后没有其他请求引入,但是线上环境重启后会不断有请求过来,所以CPU飙高的时间会持续时间更长。
  对于性能测试环境,重启之后的进行第一次并发测试,前期负载同样会很高,如下图:
  同样,在测试开始后通过top-H+jstack分析堆栈信息,分析得到两个原因:
  启动各种各样的线程进行处理请求,如AJP线程、和数据通信的线程、和ActiveMQ通信的线程等,会短时间内耗费一些资源
  另外,测试刚启动时,"C2CompilerThread1"该线程耗费资源过多,会一段时间内持续在40%~80%的CPU消耗
  测试时,增加-XX:+TieredCompilation该参数,对比资源使用情况如下:
  并发50个线程时,增加参数之前(左图)和增加参数后(右图)
  
    并发100个线程,增加参数前(左图)和增加参数后(右图)
  结论:
  可以看出即便有流量引入,-XX:+TieredCompilation该参数也是起到了一定作用,使得飙高的CPU尽快回落。
22/2<12
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号